电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Vue初始化中的選項(xiàng)合并之initInternalComponent詳解

瀏覽:130日期:2023-01-13 17:08:06

今天給大家分享Vue初始化中的選項(xiàng)合并之initInternalComponent的相關(guān)知識(shí),具體代碼如下所示:

export function initInternalComponent (vm: Component, options: InternalComponentOptions) { const opts = vm.$options = Object.create(vm.constructor.options) // doing this because it’s faster than dynamic enumeration. const parentVnode = options._parentVnode opts.parent = options.parent opts._parentVnode = parentVnode const vnodeComponentOptions = parentVnode.componentOptions opts.propsData = vnodeComponentOptions.propsData opts._parentListeners = vnodeComponentOptions.listeners opts._renderChildren = vnodeComponentOptions.children opts._componentTag = vnodeComponentOptions.tag if (options.render) { opts.render = options.render opts.staticRenderFns = options.staticRenderFns }}

initInternalComponent方法接受兩個(gè)參數(shù),第一個(gè)參數(shù)是組件實(shí)例,即this。第二個(gè)參數(shù)是組件構(gòu)造函數(shù)中傳入的option,這個(gè)option根據(jù)上文的分析,他是在createComponentInstanceForVnode方法中定義的:

export function createComponentInstanceForVnode ( vnode: any, // we know it’s MountedComponentVNode but flow doesn’t parent: any, // activeInstance in lifecycle state): Component { const options: InternalComponentOptions = { _isComponent: true, _parentVnode: vnode, parent } // check inline-template render functions const inlineTemplate = vnode.data.inlineTemplate if (isDef(inlineTemplate)) { options.render = inlineTemplate.render options.staticRenderFns = inlineTemplate.staticRenderFns } return new vnode.componentOptions.Ctor(options)}

option中有三個(gè)屬性值,_isComponent上面已經(jīng)提到過(guò)了;_parentVode其實(shí)就是該組件實(shí)例的vnode對(duì)象(createComponentInstanceForVnode就是根據(jù)這個(gè)vnode對(duì)象去創(chuàng)建一個(gè)組件實(shí)例);parent則是該組件的父組件實(shí)例對(duì)象。然后我們來(lái)看看具體initInternalComponent做了什么操作:

const opts = vm.$options = Object.create(vm.constructor.options)

首先,用Object.create這個(gè)函數(shù),把組件構(gòu)造函數(shù)的options掛載到vm.$options的__proto__上。

const parentVnode = options._parentVnodeopts.parent = options.parentopts._parentVnode = parentVnode

接下把傳入?yún)?shù)的option的_parentVode和parent掛載到組件實(shí)例$options上。用我們?cè)趦煞N策略里的那個(gè)例子來(lái)說(shuō),parent就是我們組件的根實(shí)例,而_parentVnode就是<comp :msg='msg' @log-msg='logMsg'></comp>生成的一個(gè)Vnode對(duì)象。

const vnodeComponentOptions = parentVnode.componentOptionsopts.propsData = vnodeComponentOptions.propsDataopts._parentListeners = vnodeComponentOptions.listenersopts._renderChildren = vnodeComponentOptions.childrenopts._componentTag = vnodeComponentOptions.tag

然后把父組件里的vnode上的四個(gè)屬性掛載到我們的$options上,還是用那個(gè)例子來(lái)說(shuō),propsData就是根據(jù):msg='msg'生成的,他的值就是在根組件里定義的那個(gè)msg{msg: 'props-message'}。而_parentListeners就是根據(jù)@log-msg='logMsg'生成的,他的值是logMsg這個(gè)定義在父組件中的方法。

if (options.render) { opts.render = options.render opts.staticRenderFns = options.staticRenderFns}

最后就是如果傳入的option中如果有render,把render相關(guān)的也掛載到$options上。因此,這個(gè)initInternalComponent主要做了兩件事情:1.指定組件$options原型,2.把組件依賴于父組件的props、listeners也掛載到options上,方便子組件調(diào)用。

總結(jié)

到此這篇關(guān)于Vue初始化中的選項(xiàng)合并之initInternalComponent詳解的文章就介紹到這了,更多相關(guān)Vue初始化選項(xiàng)合并內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 置顶式搅拌器-优莱博化学防爆冰箱-磁驱搅拌器-天津市布鲁克科技有限公司 | 我车网|我关心的汽车资讯_汽车图片_汽车生活! | 寮步纸箱厂_东莞纸箱厂 _东莞纸箱加工厂-东莞市寮步恒辉纸制品厂 | 婚博会2024时间表_婚博会门票领取_婚博会地址-婚博会官网 | 金属波纹补偿器厂家_不锈钢膨胀节价格_非金属伸缩节定制-庆达补偿器 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 体视显微镜_荧光生物显微镜_显微镜报价-微仪光电生命科学显微镜有限公司 | 【官网】博莱特空压机,永磁变频空压机,螺杆空压机-欧能优 | 医学模型生产厂家-显微手术模拟训练器-仿真手术模拟训练系统-北京医教科技 | 自动焊锡机_点胶机_螺丝机-锐驰机器人 | 小学教案模板_中学教师优秀教案_高中教学设计模板_教育巴巴 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 涡街流量计_LUGB智能管道式高温防爆蒸汽温压补偿计量表-江苏凯铭仪表有限公司 | 超声波成孔成槽质量检测仪-压浆机-桥梁预应力智能张拉设备-上海硕冠检测设备有限公司 | 河南膏药贴牌-膏药代加工-膏药oem厂家-洛阳今世康医药科技有限公司 | 同学聚会纪念册制作_毕业相册制作-成都顺时针宣传画册设计公司 | 立式矫直机_卧式矫直机-无锡金矫机械制造有限公司 | 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | 合肥通道闸-安徽车牌识别-人脸识别系统厂家-安徽熵控智能技术有限公司 | 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | 上海诺狮景观规划设计有限公司| 膏剂灌装旋盖机-眼药水灌装生产线-西林瓶粉剂分装机-南通博琅机械科技 | 臭氧实验装置_实验室臭氧发生器-北京同林臭氧装置网 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 双工位钻铣攻牙机-转换工作台钻攻中心-钻铣攻牙机一体机-浙江利硕自动化设备有限公司 | 离子色谱自动进样器-青岛艾力析实验科技有限公司 | 纸箱抗压机,拉力机,脂肪测定仪,定氮仪-山东德瑞克仪器有限公司 | 粘度计,数显粘度计,指针旋转粘度计 | 手板_手板模型制作_cnc手板加工厂-东莞天泓 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 艺术涂料|木纹漆施工|稻草漆厂家|马来漆|石桦奴|水泥漆|选加河南天工涂料 | 潍坊大集网-潍坊信息港-潍坊信息网| 北京四合院出租,北京四合院出售,北京平房买卖 - 顺益兴四合院 | 金属雕花板_厂家直销_价格低-山东慧诚建筑材料有限公司 | 中央空调温控器_风机盘管温控器_智能_液晶_三速开关面板-中央空调温控器厂家 | 阿里巴巴诚信通温州、台州、宁波、嘉兴授权渠道商-浙江联欣科技提供阿里会员办理 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 长江船运_国内海运_内贸船运_大件海运|运输_船舶运输价格_钢材船运_内河运输_风电甲板船_游艇运输_航运货代电话_上海交航船运 | 耐高温硅酸铝板-硅酸铝棉保温施工|亿欧建设工程 | 依维柯自动挡房车,自行式国产改装房车,小型房车价格,中国十大房车品牌_南京拓锐斯特房车 - 南京拓锐斯特房车 |