您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Vue入门:todolist实例带你入门全局组件和局部组件

2025/2/26 10:51:29发布26次查看
在理解入门全局组件和局部组件之前,我们有必要了解什么是“组件化”的概念。
组件化可以理解为页面的一个组件或者一个部分,例如下图,红框部分可以划分成一个组件,我们只需要写好一个组件,然后循环数据即可。这个组件可能在在首页、列表页等任何地方使用,并不仅仅局限于当前页面。
我们仍然以最简单的todolist入门vue的全局组件和局部组件。我们把25edfb22a4f469ecb59f1190150159c6bed06894275b65c1ab86501b08a632eb拿出来作为一个组件,那么我们分别看看全局组件和局部组件分别如何实现。
全局组件
<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起来吧!
以上就是vue入门:todolist实例带你入门全局组件和局部组件的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product