vuejs的两个核心是什么

vuejs的两个核心是数据驱动组件系统。数据驱动也就是数据的双向绑定,用于保证数据和视图的一致性。组件系统能够把页面抽象成多个相对独立的模块;可以实现代码重用,提高开发效率和代码质量,便于代码维护。

vuejs的两个核心是什么

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

vue.js的两大核心:1. 数据驱动 ————- 2.组件系统

1. 数据驱动,也就是数据的双向绑定

数据发生变化后,会重新对页面渲染,这就是Vue响应式,那么这一切是怎么做到的呢?

想完成这个过程,我们需要:

立即学习“前端免费学习笔记(深入)”;

侦测数据的变化收集视图依赖了哪些数据数据变化时,自动“通知”需要更新的视图部分,并进行更新

对应专业俗语分别是:

数据劫持 / 数据代理依赖收集发布订阅模式  

也就是说:Vue 响应式核心就是,getter 的时候会收集依赖,setter 的时候会触发依赖更新

vue将遍历data中对象的所有property,并使用 Object.defineProperty 把这些 property 全部转为 getter/setter。

这些 getter/setter 对用户来说是不可见的,但是在内部它们让 Vue 能够追踪依赖,在 property 被访问和修改时通知变更。

每个组件实例都对应一个 watcher 实例,它会在组件渲染的过程中把“接触”过的数据 property 记录为依赖。

getter 的时候我们会收集依赖,依赖收集就是订阅数据变化watcher的收集,依赖收集的目的是当响应式数据发生变化时,能够通知相应的订阅者去处理相关的逻辑。

setter 的时候会触发依赖更新,之后当依赖项的 setter 触发时,会通知 watcher,从而使它关联的组件重新渲染。

总结:

1)原理:

当创建 Vue 实例时,vue 会遍历 data 选项的属性,利用 Object.defineProperty 为属性添加 getter 和 setter 对数据的读取进行劫持(getter 用来依赖收集,setter 用来派发更新),并且在内部追踪依赖,在属性被访问和修改时通知变化。

每个组件实例会有相应的 watcher 实例,会在组件渲染的过程中记录依赖的所有数据属性(进行依赖收集,还有 computed watcher,user watcher 实例),之后依赖项被改动时,setter 方法会通知依赖与此 data 的 watcher 实例重新计算(派发更新),

从而使它关联的组件重新渲染。

2)实现过程:

    我们已经知道实现数据的双向绑定,首先要对数据进行劫持监听,所以我们需要设置一个监听器Observer,用来监听所有属性。如果属性发上变化了,就需要告诉订阅者Watcher看是否需要更新。

因为订阅者是有很多个,所以我们需要有一个消息订阅器Dep来专门收集这些订阅者,然后在监听器Observer和订阅者Watcher之间进行统一管理的。接着,我们还需要有一个指令解析器Compile,对每个节点元素进行扫描和解析,

将相关指令对应初始化成一个订阅者Watcher,并替换模板数据或者绑定相应的函数,此时当订阅者Watcher接收到相应属性的变化,就会执行对应的更新函数,从而更新视图。因此接下去我们执行以下3个步骤,实现数据的双向绑定:

1.实现一个监听器Observer,用来劫持并监听所有属性,如果有变动的,就通知订阅者。

2.实现一个订阅者Watcher,可以收到属性的变化通知并执行相应的函数,从而更新视图。

3.实现一个解析器Compile,可以扫描和解析每个节点的相关指令,并根据初始化模板数据以及初始化相应的订阅器

注:Proxy 是 JavaScript 2015 的一个新特性。Proxy 的代理是针对整个对象的,而不是对象的某个属性,因此不同于 Object.defineProperty 的必须遍历对象每个属性,Proxy 只需要做一层代理就可以监听同级结构下的所有属性变化,当然对于深层结构,递归还是需要进行的。此外Proxy支持代理数组的变化。Proxy 就是vue3.0使用的方法

2. 组件系统

认识:

1)能够把页面抽象成多个相对独立的模块;

2)实现代码重用,提高开发效率和代码质量,便于代码维护

组件的核心选项

1 模板(template):模板声明了数据和最终展现给用户的DOM之间的映射关系。

2 初始数据(data):一个组件的初始数据状态。对于可复用的组件来说,这通常是私有的状态。

3 接受的外部参数(props):组件之间通过参数来进行数据的传递和共享。

4 方法(methods):对数据的改动操作一般都在组件的方法内进行。

5 生命周期钩子函数(lifecycle hooks):一个组件会触发多个生命周期钩子函数,最新2.0版本对于生命周期函数名称改动很大。

6 私有资源(assets):Vue.js当中将用户自定义的指令、过滤器、组件等统称为资源。一个组件可以声明自己的私有资源。私有资源只有该组件和它的子组件可以调用。

相关推荐:《vue.js教程》

以上就是vuejs的两个核心是什么的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3019572.html

(0)
上一篇 2025年3月13日 05:29:09
下一篇 2025年3月7日 17:37:35

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vuejs怎么修改背景色

    vuejs修改背景色的方法:1、在index.html中引入公用的css样式;2、通过添加“beforeCreate () {…}”代码修改单个组件的背景色即可。 本文操作环境:windows7系统、vue2.5.17版、Del…

    2025年3月13日
    200
  • vuejs怎么设置title

    vuejs设置title的方法:1、通过npm install安装“vue-wechat-title”;2、在main.js中引入“vue-wechat-title”;3、在index.js中给每个路由添加title即可。 本文操作环境:w…

    2025年3月13日
    200
  • vuejs中项目名怎么更改

    更改方法:1、打开项目根目录下“package.json”文件,将“name”项的值改成新的项目名;2、删除“node_modules”文件夹;3、在终端中进入项目文件夹,执行“npm install”和“npm run dev”命令即可。…

    2025年3月13日
    200
  • vuejs怎么引入css

    vuejs引入css的方法:1、在“app.vue”中的“”下直接引入对应的路径;2、将“@import”改成“”引入外部样式。 本文操作环境:Windows7系统、vue2.9.6版,DELL G3电脑。 vue.js引入外部CSS样式?…

    2025年3月13日
    200
  • vuejs怎么将毫秒转成日期

    vuejs将毫秒转成日期的方法:1、定义过滤器“filters.js”;2、在所用之处引入“filters.js”;3、通过“formatDate(data,’yyyy-MM-dd’);”进行转换即可。 本文操作环境…

    2025年3月13日 编程技术
    200
  • vuejs中axios用法是什么

    vuejs中axios的使用方法:1、安装axios;2、在main.js页面引用axios;3、通过“created(){this.$axios({method:’post’,url:’api&#821…

    2025年3月13日
    200
  • vuejs slot 怎么使用

    vuejs slot的使用方法:1、在子组件内放一些DOM;2、通过slot实现显示或者隐藏DOM,代码如“new Vue({el: “#app”,data: {},components:{children:{&#8…

    2025年3月13日 编程技术
    200
  • vuejs怎么改变css

    vuejs改变css的方法:1、使用“v-bind:class”或者“v-bind:style”指令修改css样式;2、直接通过操作dom来对css样式进行更改。 本文操作环境:Windows7系统、vue2.9.6版,DELL G3电脑。…

    2025年3月13日
    200
  • vuejs和vue的区别是什么

    vuejs和vue没有区别,vue只是vuejs的简称;而vuejs就是一套用于构建用户界面的渐进式JavaScript框架;与其它大型框架不同的是,Vue被设计为可以自底向上逐层应用。 本文操作环境:Windows7系统、vue2.9.6…

    2025年3月13日
    200
  • vuejs怎么隐藏当前元素

    vuejs隐藏当前元素的实现方法:1、在页面挂载完后,监听全局点击事件;2、获取当前点击的元素,根据需求获取当前元素本身的属性;3、判断当前点击元素与要隐藏的元素是否相同;4、当前点击元素与要隐藏的元素不相同则隐藏。 本文操作环境:Wind…

    2025年3月13日 编程技术
    200

发表回复

登录后才能评论