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


本文摘自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》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...