本文实例讲述了Vue.extend实现挂载到实例上的方法。分享给大家供大家参考,具体如下:
这里主要是做个笔记
根据官网的说法,Vue.extend:是使用基础 Vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。
官网的用法是:
<div id="mount-point"></div>
// 创建构造器 var Profile = Vue.extend({ template: '<p>{{firstName}} {{lastName}} aka {{alias}}</p>', data: function () { return { firstName: 'Walter', lastName: 'White', alias: 'Heisenberg' } } }) // 创建 Profile 实例,并挂载到一个元素上。 new Profile().$mount('#mount-point')
最终结果如下:
<p>Walter White aka Heisenberg</p>
感觉这样写不太美观
于是改为下面这样写:
在文件夹./src/component/expend,新建两个文件:main.js和main.vue
main.vue就是你的组件,爱怎么写怎么写
main.js是把组件挂载到实例上,代码如下:
import Vue from 'Vue' import Main from './main.vue' let Builder = Vue.extend(Main) export default { install (vue) { vue.prototype.$YOURNAME = this.getComponent }, getComponent (param) { let instance = new Builder({ propsData: { param } }) instance.vm = instance.$mount() document.body.appendChild(instance.vm.$el) return instance } }
在入口文件main.js,添加代码:
import Vue from 'Vue' import myComponent from './src/component/expend/main.js' Vue.use(myComponent)
然后在页面中就可以这样使用了:
this.$YOURNAME(param)
希望本文所述对大家vue.js程序设计有所帮助。
Vue.extend,挂载,实例
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。