大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
前言
汕城网站建设公司成都创新互联,汕城网站设计制作,有大型网站制作公司丰富经验。已为汕城上1000家提供企业网站建设服务。企业网站搭建\成都外贸网站制作要多少钱,请找那个售后服务好的汕城做网站的公司定做!
日常中我们要使用一个弹框组件的方式通常是先通过Vue.component 全局或是 component 局部注册后,然后在模版中使用。接下来我们尝试编程式的使用组件。
实现
其实步骤很简单
document.createElement
其实想要插入一个元素,通过 document.createElement 就可以实现,并非一定需要上面两步,但是涉及到组件的复杂度、样式设置、可维护性所以使用创建构造器的方式比较可行。
Vue.extend()
首先来定义这个弹框的结构和样式,就是正常的写组件即可
这里是标题
{{ cancelText }}{{ sureText }}
将创建构造器和挂载到目标元素上的逻辑抽离出来,多处可以复用
export function extendComponents(component,callback){ const Action = Vue.extend(component) const div = document.createElement('div') document.body.appendChild(div) const ele = new Action({ propsData:{ cancelText:'cancel', sureText:'sure', close:()=>{ ele.$el.remove() callback&&callback() } } }).$mount(div) }
上面代码需要注意以下几点:
Vue.extend 和 Vue.component component 的区别
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。