Vue2源码笔记(3)运行时-创建一个vue实例之init

前言

经过前面的铺垫,我们现在可以来到运行时了!在运行时中,Vue2又有怎样的运行逻辑呢?话不多说,让我们开始吧!

(BTW,介绍运行时的时候,我会先从一个更简单的运行时例子起手,等到后边相关的内容出现后再接上编译时的渲染函数那部分。)

创建实例

所以先来看一个最简单的运行时例子,也就是创建vue实例

css 复制代码
var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

在这个例子中,Vue2将如何运行呢?

javascript 复制代码
/**
 * Vue
 * @param {*} options options 配置对象
 */
 function Vue(options) {
     this._init(options); // 使用的是Vue.prototype._init()
 }

在这里_init()是通过原型拓展的,Vue中的功能函数大多也是通过这一途径拓展的,接下来我们会看到越来越多类似的内容,暂且按下不表。

先来看看_init()是如何拓展的:

javascript 复制代码
/**
 * 为Vue原型拓展Vue.prototype._init()
 * @param {Vue} Vue原型
 */
function initMixin(Vue) {
    Vue.prototype._init = function(options) {
    }
}
​
scss 复制代码
function Vue(options) {
    this._init(options);
}
​
initMixin(Vue); // 在入口文件中执行该拓展代码

然后我们再来看看这个函数_init究竟做了什么:

ini 复制代码
function initMixin(Vue) {
    Vue.prototype._init = function(options) {
        const vm = this; // 实例创建时this指向对应的vue实例
        // 设置属性
        vm._uid = uid++;
        vm._isVue = true;
        vm.__v_skip = true;
        vm._self = vm;
        // js中对象是引用类型,所以以上操作会为内存中的对象添加这些属性
        // ..._init()中很多设置属性的操作,为了先把基础的核心思想整理清楚,这里省略了一些操作,并且简化了一些操作,比如:
        vm.$options = options;
        
        initLifecycle(vm);
        initEvents(vm);
        initRender(vm);
        callHook(vm, 'beforeCreate', undefined, false /* setContext */);
        initInjections(vm);
        initState(vm); // 数据初始化
        initProvide(vm);
        
        if (vm.$options.el) {
        vm.$mount(vm.$options.el); // 进入挂载流程
    }
    }
}

_init()中执行了多个初始化方法,但接下来我们将首先对initState()进行整理,在这里我们将接触到Vue的核心------响应式中的数据劫持和数据代理。

总结

在这篇中,我们稍微了解了一下Vue实例的初始化步骤,为我们接下来对响应式数据的处理做一个铺垫。

相关推荐
一嘴一个橘子17 分钟前
vue.js 视频截取为 gif - 2(将截取到的gif 转换为base64 、file)
vue.js
Mintopia23 分钟前
🤖 算法偏见修正:WebAI模型的公平性优化技术
前端·javascript·aigc
Mintopia26 分钟前
🧩 TypeScript防御性编程:让Bug无处遁形的艺术
前端·typescript·函数式编程
JarvanMo28 分钟前
🔔 Flutter 本地通知: 吸引用户的完整指南—即使在他们离线时也能实现
前端
你想考研啊34 分钟前
一、redis安装(单机)和使用
前端·数据库·redis
江城开朗的豌豆36 分钟前
小程序与H5的“握手言和”:无缝嵌入与双向通信实战
前端·javascript·微信小程序
天蓝色的鱼鱼36 分钟前
React 19 发布一年后:对比 React 18,带来了哪些惊喜与变革
前端·react.js
你的电影很有趣40 分钟前
lesson73:Vue渐进式框架的进化之路——组合式API、选项式对比与响应式新范式
javascript·vue.js
江城开朗的豌豆41 分钟前
小程序静默更新?用户却无感?一招教你“强提醒”
前端·javascript·微信小程序
小张成长计划..42 分钟前
VUE工程化开发模式
前端·javascript·vue.js