两者在使用效果上没有任何区别,都是为了将实例化后的vue挂载到指定的dom元素中。
如果在实例化vue的时候指定el,则该vue将会渲染在此el对应的dom中,反之,若没有指定el,则vue实例会处于一种“未挂载”的状态,此时可以通过$mount来手动执行挂载。
注:如果$mount没有提供参数,模板将被渲染为文档之外的的元素,并且你必须使用原生DOM API把它插入文档中。
例如:
var MyComponent = Vue.extend({ template: '<div>Hello!</div>' }) // 创建并挂载到 #app (会替换 #app) new MyComponent().$mount('#app') // 同上 new MyComponent({ el: '#app' }) // 或者,在文档之外渲染并且随后挂载 var component = new MyComponent().$mount() document.getElementById('app').appendChild(component.$el)
补充知识:Vue 实例挂载方法($mount)的实现
在 Vue 的 _init 方法中已经回调了beforeCreate 和created这两个生命周期钩子,在此之后就进行了实例的挂载
if (vm.$options.el) { // 挂载实例 vm.$mount(vm.$options.el); }
在挂载函数中,将要进行 beforeMount 和 mounted 的回调。
在不同的平台下对于 $mount 函数的实现是有差异的,下面考虑 web 平台的 runtime-with-compiler 版本 , 其在web平台下的定义如下(src/platforms/web/runtime/index.js)
import { mountComponent } from 'core/instance/lifecycle'; Vue.prototype.$mount = function( el"htmlcode">import Vue from './runtime/index'; const mount = Vue.prototype.$mount; // 缓存 上面的 $mount 方法 Vue.prototype.$mount = function( el"htmlcode">export function mountComponent( vm: Component, el: "htmlcode">constructor( vm: Component, expOrFn: string | Function, cb: Function, options"htmlcode">if (typeof expOrFn === 'function') { this.getter = expOrFn; }也就是说updateComponent()方法被设置为了getter()方法
看到构造函数的最后
this.value = this.lazy "htmlcode">const vm = this.vm; try { value = this.getter.call(vm, vm); }我们看到调用了getter()方法,也就是调用了updateComponent()方法。
2. 为什么根实例的$vnode为空
在initRender()函数中有如下代码
const parentVnode = vm.$vnode = options._parentVnode;
也就是说 当前实际的 $vnode 值为其父节点的vnode值
而根实例没有父节点,故其$vnode值就为空了,所以会执行
if (vm.$vnode == null) { vm._isMounted = true; callHook(vm, 'mounted'); }那么子节点的mounted回调是在那里执行的呢?
在 path()(core/vdom/patch.js) 函数中有如下代码
function invokeInsertHook(vnode, queue, initial) { if (isTrue(initial) && isDef(vnode.parent)) { vnode.parent.data.pendingInsert = queue; } else { for (let i = 0; i < queue.length; ++i) { queue[i].data.hook.insert(queue[i]); // 这里 } } }在循环queue的时候,调用了 insert()方法,该方法为 VNodeHooks,其在componentVNodeHooks(core/vdom/create-component.js)中声明,代码如下
const componentVNodeHooks = { insert(vnode: MountedComponentVNode) { const { context, componentInstance } = vnode; if (!componentInstance._isMounted) { componentInstance._isMounted = true; callHook(componentInstance, 'mounted'); // 这里 } if (vnode.data.keepAlive) { if (context._isMounted) { queueActivatedComponent(componentInstance); } else { activateChildComponent(componentInstance, true /* direct */); } } }, }由于 path() 方法在 _update()函数中调用,这部不再重点说明。
下节我们将来说说render() 和 _update() 方法的实现
以上这篇vue $mount 和 el的区别说明就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
快活林资源网 Design By www.csstdc.com广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!快活林资源网 Design By www.csstdc.com暂无评论...
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]