vue2 自定义组件

1st.定义自定义组件

    自定义组件是解决代码复用问题的方法,封装自定义组件可以使得在处理许多相似业务时更方便快捷的编写代码。

1.1.局部定义方法:

    局部就是只能在一个vue实例中使用,定义方法是使用components对象编写自定义组件:

new Vue({

            el: '#app',

            data: {

            },

            components: {

                "b-box": {

                    template: `<div class="box">

                                                <h2 class="title">Hello {{ name }} </h2>

                                    </div>`,

                    data(){

                                return {

                                              name:"张三"

                        }

                },

            }

        })

    注:1.在components对象中,属性名即为自定义组件的名称,之后使用自定义组件也是使用这个属性名的标签,注意,因为html中标签不区分大小写,而这里的属性名是要在html中使用的,所以命名不能使用大写字母,应使用全小写加连字符-来连接代替驼峰式命名法。

            2.每个组件就是一个小型的Vue实例,它里面除了不能设置el选项,要使用组件的模板template来写组件在使用时要渲染的内容,而且模板中要有一个根标签

            3.data属性不能使用对象来写,要使用方法的返回对象来写。

1.2.全局定义方法:

    在全局定义的自定义组件可以在页面中所有的vue实例中使用。在定义时使用Vue.component方法:

Vue.component( "b-box",{

                    template: `<div class="box">

                                                <h2 class="title">Hello{{ name }}</h2>

                                    </div>`,

                                  data(){

                                            return {

                                                        name:"张三"

                                                       }

                                            }

})

    

2nd.使用自定义组件

    使用自定义组件只要在html中使用自定义组件名称的标签即可,与普通标签一样,可以使用通用的vue语法如 v-for v-if 等

<b-box></b-box>

3rd.自定义属性

    自定义组件是灵活的,它需要渲染的值也可以让vue实例通过自定义属性的方法传给内部。自定义属性的定义使用 props 来定义:

props简写:

 Vue.component("b-box", {

            template: `<div class="box">

                            <h2 class="title">Hello{{ name }}</h2>

                            <p>{{value1}}</p>

                            <p>{{value2}}</p>

                </div>`,

            data() {

                return {

                    name: "张三"

                }

            },

            props: ["value1", "value2"]

        })

props详写

Vue.component("b-box", {

            template: `<div class="box">

                            <h2 class="title">Hello{{ name }}</h2>

                            <p>{{value1}}</p>

                            <p>{{value2}}</p>

                </div>`,

            data() {

                return {

                    name: "张三"

                }

            },

            props: {

                value1:{

                    //数据类型

                    type:String,

                    //是否必填

                    required: false,

                    //默认值

                    default:"666"

                },

                value2:{

                    //数据类型

                    type:String,

                    //是否必填

                    required: true,

                    //默认值

                    default:"888"

                },

            }

        })

注:自定义属性的命名不支持用驼峰命名,不能使用大写。

4rd.自定义属性的使用

    与普通标签一样,自定义属性的使用是在标签中加入自定义属性名,并给与值:

 <b-box value1="666" value2="877"></b-box>

5rd.自定义属性的中转

    自定义属性的值传到内部时是只读的,不能修改,所以当需要改变自定义属性值的时候,需要先在自定义组件的data中定义一个变量来存放传进来的值,然后使用这个变量来操作:

Vue.component("b-box", {

            template: `<div class="box">

                            <h2 class="title">Hello{{ name }}</h2>

                            <p>{{value1}}</p>

                            <p>{{value}}</p>

                            <button @click = "value++">++</button>

                </div>`,

            data() {

                return {

                    name: "张三",

                    value:this.value1

                }

            },

            props: {

                value1:{

                    //数据类型

                    type:Number,

                },

            }

        })

6rd.自定义事件

    因为传到自定义组件中的值不能修改,当通过中转的方法修改了的值在原vue中需要使用时,需要通过自定义事件的方法来获取到修改了之后的数据,自定义事件使用vue的 $emit 方法来定义:

Vue.component("b-box", {

            template: `<div class="box">

                            <h2 class="title">Hello{{ name }}</h2>

                            <p>{{value1}}</p>

                            <p>{{value}}</p>

                            <button @click = "value++">++</button>

                </div>`,

            data() {

                return {

                    name: "张三",

                    value:this.value1

                }

            },

            props: ["value1"],

            watch:{

                value(){

                    this.$emit('sync', this.value)

                }

            }

        })

注:自定义事件的命名不支持用驼峰命名,不能使用大写。

7rd.使用自定义事件

首先在标签中绑定自定义的事件

<b-box value1="6" @sync="sync"></b-box>

然后再方法中定义绑定的事件,通过事件对象来接受传过来的值

sync(e){

                    console.log(e);

                }

在事件中处理传过来的数据即可。

8rd.自定义组件中插槽的用法

slot 用于在组件的内部定义插槽,组件标签之间的内容,会在插槽所在位置呈现。

/html

div id='app'>

        <b-box>

            <h2>HelloWorld</h2>

        </b-box>

    </div>

/自定义组件

        Vue.component("b-box", {

            template: `<div class="box">

                            <h2 class="title">Hello{{ name }}</h2>

                            <slot></slot>

                </div>`,

            data() {

                return {

                    name: "张三",

                    value: this.value1

                }

            },

        })

效果:

插槽的用法
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,287评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,346评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,277评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,132评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,147评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,106评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,019评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,862评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,301评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,521评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,682评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,405评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,996评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,651评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,803评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,674评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,563评论 2 352

推荐阅读更多精彩内容