首页 > web前端 > js教程 > 正文

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

王雪芹
发布: 2020-08-07 16:17:44
原创
2031人浏览过

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

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

我们仍然以最简单的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定义组件样式,或者通俗说模板

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

小门道AI
小门道AI

小门道AI是一个提供AI服务的网站

小门道AI117
查看详情 小门道AI
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实例带你入门全局组件和局部组件的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号