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

互联网 20-8-7
在理解入门全局组件和局部组件之前,我们有必要了解什么是“组件化”的概念。

组件化可以理解为页面的一个组件或者一个部分,例如下图,红框部分可以划分成一个组件,我们只需要写好一个组件,然后循环数据即可。这个组件可能在在首页、列表页等任何地方使用,并不仅仅局限于当前页面。

我们仍然以最简单的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>"         })

同时还需要注意这里有一个父组件向子组件传值

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实例带你入门全局组件和局部组件的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: todolist
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:如何更好的理解Vue的MVVM 模式?

相关资讯