本篇文章为大家展示了如何使用todolist入门全局组件和局部组件,代码简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
在理解入门全局组件和局部组件之前,我们有必要了解什么是“组件化”的概念。
组件化可以理解为页面的一个组件或者一个部分,例如下图,红框部分可以划分成一个组件,我们只需要写好一个组件,然后循环数据即可。这个组件可能在在首页、列表页等任何地方使用,并不仅仅局限于当前页面。
我们仍然以最简单的todolist入门Vue的全局组件和局部组件。我们把<li></li>拿出来作为一个组件,那么我们分别看看全局组件和局部组件分别如何实现。
全局组件
<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"中。
Vue.component("TodoItem",{
props:['content'],
template:"<li>{{content}}</li>"
})
TodoItem是组件名称,在html中<todo-item></todo-item>使用
props是接收参数
template定义组件样式,或者通俗说模板
同时还需要注意这里有一个父组件向子组件传值:
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显示数据了。
局部组件
同样的效果,我们使用局部组件来试试。
<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中进行声明
components:{
'TodoItem':TodoItem
},
那么局部组件仅仅在id="root"中使用。
好了,以上就是todolist实例带你入门全局组件和局部组件,升职加薪,Vue技能赶紧get起来吧!
上述内容就是如何使用todolist入门全局组件和局部组件,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。