当前位置: 首页 > news >正文

资阳市网站建设_网站建设公司_Django_seo优化

国际婚恋网站排名,专为男人做的网站,大浪网站建设,新闻发布系统网站模板初始化应用实例 创建 Vue 实例对象 createApp 中做了两件事#xff1a; 创建 app 对象保存并重写 mount /*** 创建 Vue 实例对象*/ const createApp ((...args) {// 1、创建 app 对象#xff0c;延时创建渲染器#xff0c;优点是当用户只依赖响应式包的时候#xff0…初始化应用实例 创建 Vue 实例对象 createApp 中做了两件事 创建 app 对象保存并重写 mount /*** 创建 Vue 实例对象*/ const createApp ((...args) {// 1、创建 app 对象延时创建渲染器优点是当用户只依赖响应式包的时候可以通过 tree-shaking 移除核心渲染逻辑相关的代码减少体积const app ensureRenderer().createApp(...args)// 2、保存并重写 mountconst { mount } appapp.mount (containerOrSelector) {// ...}return app })为什么需要重写 mount 方法而不把相关逻辑放在 app 对象的 mount 方法内部来实现呢 答因为 Vue 不仅仅是为 Web 平台服务它的目标是支持跨平台渲染createApp 函数内部的 app.mount 方法是一个标准的可跨平台的组件渲染流程因此需要根据具体场景进行定制化。 使用 ensureRenderer().createApp() 来创建 app 对象 // 渲染相关的一些配置比如更新属性的方法操作 DOM 的方法 const rendererOptions {patchProp,...nodeOps }let renderer /*** 检查是否存在渲染器*/ function ensureRenderer() {return renderer || (renderer createRenderer(rendererOptions)) } /*** 创建渲染器*/ function createRenderer(options) {return baseCreateRenderer(options) } /*** 创建渲染器的基本逻辑*/ function baseCreateRenderer(options) {// 组件渲染的核心逻辑function render(vnode, container) {// ...}return {render,createApp: createAppAPI(render)} } /*** 创建应用实例的 API*/ function createAppAPI(render) {// 创建应用实例接收的两个参数rootComponent - 根组件的对象 和 rootProps - props参数return function createApp(rootComponent, rootProps null) {const app {_component: rootComponent,_props: rootProps,// app.mount 组件挂载逻辑mount(rootContainer) {// 1、创建根组件的 vnodeconst vnode createVNode(rootComponent, rootProps)// 2、利用渲染器渲染 vnoderender(vnode, rootContainer)// 3、设置应用实例的容器为根组件的容器app._container rootContainerreturn vnode.component.proxy}}return app} }重写 app.mount 方法 /*** 重写 app.mount 方法* 重写的目的* 1、让用户可以更灵活的使用 API* 2、兼容 Vue2 的写法*/ app.mount (containerOrSelector) {// 1、标准化容器可以传字符串选择器或 DOM 对象如果传的是字符串选择器则会将其转换为 DOM 对象作为最终挂载的容器const container normalizeContainer(containerOrSelector)if (!container) returnconst component app._component// 2、如果组件对象没有定义 render 函数和 template 模板则取容器的 innerHTML 作为组件模板内容if (!isFunction(component) !component.render !component.template) {component.template container.innerHTML}// 3、挂载前清空容器内容container.innerHTML // 4、真正的挂载return mount(container) }
http://www.ihoyoo.com/news/84803.html

相关文章:

  • 丽江网站建设单位网站建设公司
  • 网站商城注意事项PHP关于简单企业网站开发过程简介
  • 西安 美院 网站建设建网站义乌
  • 汕尾住房和城乡建设局网站西安做北郊做网站
  • 南充房管局网站查询房产在虚拟主机上安装wordpress
  • 企业网站建设方案ppt盐城网站app建设
  • net网站开发视频怎样做引流推广
  • 做网站在哪里做外贸高端网站开发
  • 手机如何建网站西安网页开发
  • 做得好的营销网站微信官网网站模板下载安装
  • 做个网站需要学会什么网站后台设置关键字
  • 绍兴网站建设价格上海剑展投资管理有限公司
  • ps做图哪个网站好wordpress增加类
  • 残疾人网站服务平台广州市网站建设需要审批
  • 公司注销后 网站备案吗个人介绍网页制作
  • 永州做网站费用怎么做提升网站转化率
  • 长沙市制作网站清智优化北京
  • 有九类商标可以做网站名吗django成品网站源码
  • 商业网站建设软件网站建设源码
  • 南宁网站开发培训学wordpress要多久
  • 盐城网站建设多少钱新注册公司网站建设
  • qianhu微建站wordpress最新版
  • 网站建设陆金手指谷哥9行业网站导航
  • 企业网站配色网站 做实名认证
  • 英语机构网站建设方案泰安网红瑶瑶
  • 合肥seo网站建设广告推广网站怎么做
  • 动物园网站建设的可行性分析南京网站建设咨询
  • 网站开发的缓存技术北京电商网站开发价格
  • 网站建设项目成本估算表最近国内重大新闻
  • 专门做油画交流的网站网站排名忽然不见了