本文摘自PHP中文网,作者王雪芹,侵删。
在理解入门全局组件和局部组件之前,我们有必要了解什么是“组件化”的概念。组件化可以理解为页面的一个组件或者一个部分,例如下图,红框部分可以划分成一个组件,我们只需要写好一个组件,然后循环数据即可。这个组件可能在在首页、列表页等任何地方使用,并不仅仅局限于当前页面。
我们仍然以最简单的todolist入门Vue的全局组件和局部组件。我们把<li></li>拿出来作为一个组件,那么我们分别看看全局组件和局部组件分别如何实现。
全局组件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | < div id = "root" >
< div >
< input v-model = "inputValue" />
< button @ click = "handleSubmit" >提交</ button >
</ div >
< ul >
< todo-item v-bind:content = "item" v-for = "item in list" ></ todo-item >
</ ul >
</ div >
< script >
Vue.component("TodoItem",{
props:['content'],
template:"< li >{{content}}</ li >"
})
new Vue({
el:"#root",
data:{
inputValue:'',
list:[]
},
methods:{
handleSubmit:function(){
this.list.push(this.inputValue)
this.inputValue = '' //每次提交后清空
}
}
})
</ script >
|
我们使用Vue.component()来定义一个全局组件,那么这个组件在当前页面均可使用,而不仅仅是id="root"中。
1 2 3 4 | Vue.component("TodoItem",{
props:['content'],
template:"< li >{{content}}</ li >"
})
|
TodoItem是组件名称,在html中<todo-item></todo-item>使用
props是接收参数
template定义组件样式,或者通俗说模板
同时还需要注意这里有一个父组件向子组件传值:
1 | todo-item v-bind:content="item" v-for="item in list"></ todo-item >
|
我们来分析,list是输入父组件的,todo-item属于子组件,list中循环的数据item需要传递给全局组件,则用v-bind:content="item"传递,其中content就是子组件接收的数据,那么子组件定义接收props:['content']后,就可以template:"<li>{{content}}</li>"用content显示数据了。
局部组件
同样的效果,我们使用局部组件来试试。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | < div id = "root" >
< div >
< input v-model = "inputValue" />
< button @ click = "handleSubmit" >提交</ button >
</ div >
< ul >
< todo-item v-bind:content = "item" v-for = "item in list" ></ todo-item >
</ ul >
</ div >
< script >
var TodoItem={
props:['content'],
template:"< li >{{content}}</ li >"
}
new Vue({
el:"#root",
data:{
inputValue:'',
list:[]
},
components:{
'TodoItem':TodoItem
},
methods:{
handleSubmit:function(){
this.list.push(this.inputValue)
this.inputValue = '' //每次提交后清空
}
}
})
</ script >
|
和全局组件不同的是,我们通过var TodoItem={}定义局部组件,定义后还要在new Vue中进行声明
1 2 3 | components:{
'TodoItem':TodoItem
},
|
那么局部组件仅仅在id="root"中使用。
好了,以上就是todolist实例带你入门全局组件和局部组件,升职加薪,Vue技能赶紧get起来吧!
以上就是Vue入门:todolist实例带你入门全局组件和局部组件的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
vue配什么ui框架比较好
vue架构是什么
vue实现员工信息录入功能的方法
vue中v-if和v-show的区别是什么?
vue和react状态管理有啥区别?
vue-loader是什么?
在vue中destroy是什么意思?
浅谈vue项目中使用npm安装bootstrap和jquery
2021年值得收藏的17个vue 后台管理模板
vue项目全局使用axios的方法介绍
更多相关阅读请进入《vue》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » Vue入门:todolist实例带你入门全局组件和局部组件