Vue下拉列表实例(组件的使用)

组件化

组件化的概念

Web 中的组件其实就是页面组成的一部分,好比是电脑中的每一个元件(如硬盘、键盘、鼠标),它是一个具有独立的逻辑和功能或界面,同时又能根据规定的接口规则进行相互融合,变成一个完整的应用,页面就是有一个个类似这样的部分组成,比如导航、列表、弹窗、下拉菜单等。页面只不过是这些组件的容器,组件自由组合形成功能完善的界面,当不需要某个组件,或者想要替换某个组件时,可以随时进行替换和删除,而不影响整个应用的运行。

组件化的特性

  1. 高内聚性,组建功能必须是完整的,如我要实现下拉菜单功能,那在下拉菜单这个组件中,就把下拉菜单所需要的所有功能全部实现。
  2. 低耦合度,通俗点说,代码独立不会和项目中的其他代码发生冲突。在实际工程中,我们经常会涉及到团队协作,传统按照业务线去编写代码的方式,就很容易相互冲突,所以运用组件化方式就可大大避免这种冲突的存在、
  3. 每一个组件都有子集清晰的职责,完整的功能,较低的耦合便于单元测试和重复利用。

组件化的优点

  • 提高开发效率
  • 方便重复使用
  • 简化调试步骤
  • 提升整个项目的可维护性
  • 便于协同开发

Vue中的组件

vue 中的组件是一个自定义标签形式,Vue.js的编译器为它添加特殊功能;
vue也可以扩展原生的html元素,封装可重用的代码。

vue组件的构成

  • 样式及结构
  • 行为逻辑
  • 数据

注册组件

  • 组件注册必须在指定实例之前执行。
  • 建议将组件提取出来放在单独js文件中,按需引用

全局注册

可以在任何模版中使用,使用之前必须先注册

  • 语法: Vue.component(tagName, options)
  • 命名约定: “驼峰”格式,或者“烤串”格式, 组件引用名必须一致
  • Exp:
<custom-select></custom-select>
Vue.component("custom-select", {
    template: `<section class="wrap">
        <section class="searchIpt clearFix">
            <section class="clearFix">
                <input type="text" class="keyWord" />
                <input type="button" value="Go" />
                <span></span>
            </section>
            <ul class="list">
                <li>111111</li>
                <li>2222</li>
                <li>3333</li>
                <li>4444</li>
                <li>5555</li>
                <li>6666</li>
            </ul>
        </section>
    </section> `,
});

局部注册

通过使用组件实例选项注册,可以使组件仅在另一个指定实例/组件的作用域中可用

new Vue({
    el: '#app',
    //组件队列
    components: {
        //组件名称
        "custom-select": {
            template: `<section class="wrap">
                        <section class="searchIpt clearFix">
                            <section class="clearFix">
                                <input type="text" class="keyWord" />
                                <input type="button" value="查询" />
                                <span></span>
                            </section>
                            <ul class="list">
                                <li>111111</li>
                                <li>2222</li>
                                <li>3333</li>
                                <li>4444</li>
                                <li>5555</li>
                                <li>6666</li>
                            </ul>
                        </section>
                    </section>`
        },
        "test-dom": {
            template: `<p>测试文字</p>`
        }
    }
});

也可以将组件对象抽离用一变量缓存出来,如下:

var Temp = {
    template: `<section class="wrap">
                        <section class="searchIpt clearFix">
                            <section class="clearFix">
                                <input type="text" class="keyWord" />
                                <input type="button" value="查询" />
                                <span></span>
                            </section>
                            <ul class="list">
                                <li>111111</li>
                                <li>2222</li>
                                <li>3333</li>
                                <li>4444</li>
                                <li>5555</li>
                                <li>6666</li>
                            </ul>
                        </section>
                    </section>`
};

new Vue({
    el: "#app",
    components: {
        // <custom-select> 将只在父模板可用
        'custom-select': Child,
    }
});

组件间的通信

父组件要给自组件传递数据,子组件需要将它内部发生的事情告知给父组件。

组件中的数据

组件中的数据必须是函数, 如果它们共用一个对象,在更改其中一个组件数据时,也会影响到其它的组件。

换做函数形式,每个组件都能够有自己独立的数据,从而不会影响到其它的组件,有点像解耦的概念。

组件信息传递
传递情况
父组件 =>子组件 1. 在父级组件上使用自定义属性绑定数据; 2.使用props声明自定义属性名
子组件 =>父组件 1. 在父级组件上绑定自定义事件v-on监听自定义事件;2. 使用$emit()触发父组件所关心的自定义事件。

父组件 =>子组件

组件实例的作用域是孤立的,不能在子组件直接用父组件的数据。

可以在组件上使用自定义属性绑定数据,在组件中需要显式的用选项参数props声明自定义属性名。

子组件 =>父组件

需要用到自定义事件,父组件用$on监听自定义事件,使用$emit()触发父组件所关心的自定义事件。

Code

<custom-select btn-value="查询" :list="list1"></custom-select>
<custom-select btn-value="搜索" :list="list2"> </custom-select>
// 父组件
Vue.component("custom-select", {
    /*
       !此处数据类型必须是一个函数形式,不能直接写对象。
        每个组件都是相互独立的,如果它们共用一个对象,在更改一个组件数据的时候,会影响到其它
        组件,如果是函数的话,每个组件就都有自己的独立数据,相互之间不会影响。
    */
    data: function() {
        return {
            selectShow: false,
            val: ""
        };
    },
    props: ["btnValue", "list"],
    template: `<section class="wrap">
                    <section class="searchIpt clearFix">
                        <section class="clearFix">
                            <input type="text" class="keyWord" :value="val"  @click="selectShow=!selectShow"/>
                            <input type="button" :value="btnValue" />
                            <span></span>
                        </section>
                        <custom-list v-show="selectShow" :list="list"  @receive="changeValueHandle"></custom-list>
                    </section>
                </section>`,
    methods: {
        changeValueHandle(value) {
            this.val = value;  //将选中的值赋给指定的input 
            this.selectShow = false;  //隐藏下拉框
        }
    }
});


// 子组件
Vue.component("custom-list", {
    props: ["list"],
    template: `
            <ul class="list">
                <li v-for="item in list" @click="selectValueHandle(item)">{{item}}</li>
            </ul>`,
    methods: {
        selectValueHandle(item) {
            //在子组件中触发,需要一个自定义事件
            // Key值 是父级的自定义事件
            this.$emit("receive", item);
        }
    }
});

new Vue({
    el: '#app',
    data: function() {
        return {
            list1: ["北京", "上海", "广州", "深圳"],
            list2: ["2017-2-25", "2017-2-26", "2017-2-27", "2017-2-28"],
        };
    }
});

特殊属性is

Vue是在浏览器解析和标准化HTML后才获取模版内容,某些不符合W3C标准的dom结构最终会被错误解析。

通过使用is来扩展HTML标签功能可以解决。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,504评论 25 707
  • 清晰记得,听得第一首民谣是赵雷的《南方姑娘》。那时候,不知道赵雷是谁,不理解歌词的含义,纯粹是喜欢整首歌的旋...
    就是兔子先生阅读 862评论 0 2
  • 01 赵客缦胡缨,吴钩霜雪明。银鞍照白马,飒沓如流星。十步杀一人,千里不留行。事了拂衣去,深藏身与名。闲过信陵饮,...
    在下王焱阅读 3,744评论 10 47
  • 好想你。这样说好像有点矫情,但我真的挺想你的,从大一开始,每次和你相遇都会觉得很开心,我很喜欢你的性格,很喜欢你的...
    初栈阅读 289评论 0 0