本文实例讲述了Vue学习之组件用法。分享给大家供大家参考,具体如下:
Vue中的模块化、可重用代码块将页面细分为一个个功能组件,而且组件之间可以嵌套。组件分为全局组件与局部组件,局部组件在实例中进行注册,并且只可以应用于该实例中。
1、 组件的使用流程:
//1、创建组件构造器 let overallDiv=Vue.extend({ template:` <div> <p>这是一个全局组件div</p> </div> ` }); //2、注册全局组件 Vue.component('overall-div',overallDiv); //3、实例化,组件只有在实例化的div内才能使用,不可以直接在页面中使用 let vue=new Vue({ el:'#app', data:{}, //在实例内注册局部组件,其创建与注册可以合为一步来写 components:{ 'local-div':{ template: ` <div> <p>这是一个局部组件div</p> </div> ` } }, methods:{ } });
在HTML页面实例化的div中使用组件:
<div id="app"> <local-div></local-div> <overall-div></overall-div> </div>
注意:一些HTML标签对放入其中的标签有限制,这时需要通过is属性将组件转化为你要放入的组件,例如<ul>标签下只能放<li>,这时,你可以使用<li is="my-component">,这样就相当于放入了<my-component>标签。
2、template模板
组件的模板除了在js中创建外,还可以使用页面中的template创建模板,注意页面中的模板只能有一个根元素,如有多个元素需要包含在一个div内,例如页面body中的模板:
<template id="myTmp"> <div> <p>这是页面中的模板</p> </div> </template>
在js中通过id号注册模板。
Vue.component('my-tmp',{ template:'#myTmp' });
3、组件的data
在组件中使用data必须以函数的形式返回,如果以属性值的形式存在,所有的组件会共享一个属性值,更改其中一个,所有的组件都会收到影响。例如一个统计被点击次数的组件:
<template id="myBtn"> <div> <button @click="count++">按钮被点击{{count}}次</button> </div> </template>
Vue.component('my-btn',{ template:'#myBtn', data () { //以函数返回的方式定义组件使用的data return { count:0 }; } }); <div id="app"> <my-btn></my-btn> <my-btn></my-btn> </div>
在页面中分别点击两个按钮,两个按钮组件的count分别计数,不会互相干扰:
4、父子组件
先创建子组件,然后再父组件内进行注册,就可以在父组件的模板内使用子组件,然后再注册父组件,这样就可以在外部调用包含子组件的父组件了,外部直接使用父组件接口,而不需要知道内部子组件的实现
注意在外部不能直接使用子组件,因为它只在父组件内进行了注册,外部看不到子组件
let child1=Vue.extend({ template:`<div>这是子组件1</div>` }); let child2=Vue.extend({ template:`<div>这是子组件2</div>` }); Vue.component('parent',{ components:{ 'c1':child1, 'c2':child2 }, //在父组件内调用子组件 template:`<div>父组件<c1></c1><c2></c2></div>` }); <div id="app"> <parent></parent> </div>
结果如图:
5、插槽slot
像生活中的容器一样,slot允许向其中插入标签、组件等内容,而在外部提供一个框子包装起来。slot分为匿名插槽与实名插槽,匿名插槽可以向其中插入任何类型的内容。
实名slot可以将内容插入指定的插槽内,就像一台电脑的主板,cpu、内存条分别有自己对应的插槽,实名插槽在模板中通过name属性规定插槽的名字,在使用时,通过标签的slot属性指定对应的name,可以将标签插入指定的插槽。
匿名插槽
<!--匿名插槽--> <template id="anonymousDiv"> <div style="width: 20%;"> <h3>这是插槽头部</h3> <slot>插槽默认显示内容</slot> <hr/> <p>插槽尾部</p> </div> </template> let vue2=new Vue({ el:'#app2', data:{ }, components:{ //绑定匿名插槽 'anonymous-slot':{ template:'#anonymousDiv' }, //绑定实名插槽 'realname-slot':{ template:'#realnameDiv' } } });
向cpu插槽内插入内容:
<div id="app2"> <anonymous-slot> <p>向插槽中插入一段文字</p> </anonymous-slot> </div>
插槽未放入内容时:插入一段文字:
实名插槽
<template id="realnameDiv"> <div> <h3>实名插槽头部</h3> <slot name="cpu">这是cpu插槽</slot> <slot name="memery">这是内存条插槽</slot> <slot name="HardDisk">这是硬盘插槽</slot> </div> </template> <realname-slot> <p slot="cpu">Intel Core i5</p> </realname-slot>
结果:cpu放入指定插槽,而其他插槽未受影响:
希望本文所述对大家vue.js程序设计有所帮助。
Vue,组件
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】