vue 局部组件和全局组件及配置

如果把一段经常用的东西封装成一个组件,那么就可以对组件扩充,将组件写的更加强大。当用的时候就只需要写一对标签就可以了,其背后的具体逻辑有多复杂,用的时候根本不用管。这就是vue组件的好处。而且在vue里面组件的结构封装的特别好,这就意味着有很好的可维护性。所有vue组件既有可重用性又有可维护性。

根据组件定义的域不同,可以分为全局组件和局部组件。定义在全局里的组件叫全局组件,定义在局部域的脚局部组件

全局组件

  1. 定义全局组件
    1.1 使用Vue.component表示定义组件,
    第一个参数:表示组件在vue里面的名字,
    第二个参数{}:表示组件的内容,组件的内容里,一些选项,如:
    (1)template表示组件模板,写的就是html代码的字符串。
    (2)methods表示组件里的方法,
Vue.component('alert',{
    template:"<button @click='onClick'>clicke me</button>",
    methods:{
        onClick:function(){
            alert('my first conponent!');
        }
    }
});

1.2 给组件一个域
定义了组件后,需要给组件一个域,不然component不知道自己要在哪里。这个域是就是我们常常写的new Vue();

new Vue({
    el:'#app',
});

html中:

<div id="app">
    <alert></alert>
    <alert></alert>
</div>

定义好组件并设置域后,就是可以在页面中放很多很多标签,相同的标签功能都是一模一样。
如上在页面中仅仅只是写了标签,甚至可以没什么内容,但是它背后的功能,还不能小瞧,它取决于想不想把它往强大里写。

  1. 多域的情况
    在js中定义多个域
Vue.component('alert',{
    template:"<button @click='onClick'>clicke me</button>",
    methods:{
        onClick:function(){
            alert('my first conponent!');
        }
    }
});

new Vue({
    el:'#app1',
});
new Vue({
    el:'#app2',
});

域两个域对应的html标签内放入自定义全局组件

<div id="app1">
    <alert></alert>
</div>
<div id="app2">
    <alert></alert>
</div>

发现:使用Vue.component()多定义的组件,对下面定义的所欲域都是可见的。但是如果我有很多的全局component,这些component都是对所有域可见的,这种感觉就像是window下的全局变量,给人的感觉特别不踏实。
有的时候,我们很确切的知道一个component只能在那一个域里面用,那么就需要定义一个局部的component

局部组件

  1. 定义局部组件
    在特定的域中使用选项components定义局部组件:
    跟全局组件和相似,只不过它是在特定域中写个components
    注意:带s的,其实我觉得也很好理解,全局每次定义的是一个全局组件,局部可以定义多个局部组件,所有是复数conmponents
new Vue({
    el:'#app1',
    components:{
        alert:{
            template:"<button @click='onClick'>clicke me</button>",
            methods:{
                onClick:function(){
                    alert('my first conponent!');
                }
            }
        }
    }
});
new Vue({
    el:'#app2',
});

上述情况,在#app1定义的局部组件,如果对应html的元素内(#app1的)加这个组件时可以的。如果在其他域,如这#app2中是不能添加这个组件的,因为该组件时局部组件,只能在#app1里使,
在对应域中定义的组件只能限制在该域中,所以局部限制在指定的局部域,全局组件全局可见。一般全局组件比较少。

我们一般可以将组件的内容功能封装出来,让结构更加清晰,还可以方便给其他一些域使用该组件功能。

let Alert = {
    template:"<button @click='onClick'>clicke me</button>",
    methods:{
        onClick:function(){
            alert('my first conponent!');
        }
    }
}

new Vue({
    el:'#app',
    components:{
        alert:Alert,
    }
});

配置组件

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>demo</title>
    <link rel="stylesheet" type="text/css" href="main.css">
</head>
<body>
<div id="app">
    <like></like>
</div>
<script src="jquery-3.3.1.js"></script>
<script src="vue.js"></script>
<script src="main.js"></script>
</body>
</html>
.like{
    background-color:pink;
}
Vue.component('like',{
    template:`
        <button @click="toggleLike" :class="{like:liked}">
            赞{{like_count}}
        </button>`,
        
    data:function(){
        return {
            like_count:10,
            liked:false,//用来判断是否点赞,初始false
        }
    },

    methods:{
        //定义点击触发的事件
        toggleLike:function(){
            if (!this.liked) {//如果当前没有点赞,注意访问当前Vue实例中的数据,可用直接用this.数据名
                this.like_count++;
                this.liked = ! this.liked;
            }else{
                this.like_count--;
                this.liked = ! this.liked;
            }
        }
    }
});

//2 给组件一个生存的域
new Vue({
    el:'#app',
});

配置like组件的过程中:

  1. 通过Vue.component("组件名",{选项1,选项2...})来定义组件
  2. template选项:配置组件模板,其实就一些可视化的内容,给用户看
  3. data选项:配置组件数据相关
    注意:这个data跟域(Vus实例)中的data不同,这里全局的data不是对象,而是个function,因为我们这做的个组件,这个组件每用一次,它都会新实例出来一个对象,这个新实例对象就有一些新的数据,这个data function就是指定我们怎么去生成这写数据。这里return出来想要的数据。
  4. methods选项:定义功能函数
  5. template中可以想正常元素一样绑定事件和绑定元素,如 :class="{like:liked},表示通过v-bind来绑定一个like类,当liked为true时,显示这个类,否则不显示。

另外由于模板有些比较大也比较长,可以用ES6的反引号``,也可以写在HTML中,通过<template id=""></template>标签,那在Vue中的template的值只需要填写ID选择器就行。如:

Vue.component('like',{

    template:'#like-tpl',
    data:function(){
        return {
            like_count:10,
            liked:false,
        }
    },
    methods:{

        toggleLike:function(){
            if (!this.liked) {
                this.like_count++;
                this.liked = ! this.liked;
            }else{
                this.like_count--;
                this.liked = ! this.liked;
            }
        }
    }
});

//2 给组件一个生存的域
new Vue({
    el:'#app',
});

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>demo</title>
    <link rel="stylesheet" type="text/css" href="main.css">
</head>
<body>
<div id="app">
    <like></like>
</div>
<template id="like-tpl">
    <button @click="toggleLike" :class="{like:liked}">
            赞{{like_count}}
    </button>
</template>
<script src="jquery-3.3.1.js"></script>
<script src="vue.js"></script>
<script src="main.js"></script>
</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342