zoukankan      html  css  js  c++  java
  • Vue_(组件通讯)组件

      Vue组件  传送门

      组件Component,可扩展HTML元素,封装可重用的代码。通俗的来说,组件将可重用的HTML元素封装成为标签方便复用;

      组件的使用:

      使用全局方法Vue.extend创建构造器;

      再使用全局方法Vue.component注册组件;

      在Vue.component里需要指明组件的名称,组件名称不能使用内置标签名称,如body

      推荐使用短横线命名规则。例:

        my-component 正确 (推荐)

        my-Component 错误

        mycomponent 正确

        Mycomponent 正确

        myComponent 错误

        MyComponent 错误

      Learn

        一、组件注册 

        二、全局组件与局部组件

        三、this is component-a

      目录结构

      

      【每个demo下方都存有html源码】

    一、组件注册  传送门

      第一种方法:使用构造器注册组件

            <div id="GaryId">
                <!--<h1>hello Vue</h1>-->
                <my-component></my-component>
            </div>
                //创建构造器
                let myComponent =  Vue.extend({
                    template:"<h1>hello Vue</h1>"
                })
                
                //注册组件
                Vue.component('my-component',myComponent);

      第二种方法:组件的简写

            <div id="GaryId">
                <!--<h1>hello Vue</h1>-->
                <my-componenta></my-componenta>
            </div>
                //注册组件的简写
                Vue.component('my-componenta',{
                    template:"<h2>hello Gary</h2>"
                })

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Gary</title>
        </head>
        <body>
            <div id="GaryId">
                <!--<h1>hello Vue</h1>-->
                <my-component></my-component>
                <my-componenta></my-componenta>
            </div>
        </body>
        
        <script type="text/javascript" src="../js/vue.js" ></script>
        <script type="text/javascript">
                
                //创建构造器
                let myComponent =  Vue.extend({
                    template:"<h1>hello Vue</h1>"
                })
                
                //注册组件
                Vue.component('my-component',myComponent);
                
                //注册组件的简写
                Vue.component('my-componenta',{
                    template:"<h2>hello Gary</h2>"
                })
                
                new Vue({
                    data:{
                        msg:'Gary'
                    }
                }).$mount("#GaryId");
        </script>
    </html>
    Gary_component.html

     二、全局组件与局部组件  传送门

      组件可分为全局组件与局部组件;

      全局组件:

        在全局API中的Vue.component注册

        该项目中所有Vue实例内均可以使用

      局部组件:

        在Vue实例中的components选项中注册

        只能在本实例中使用

      全局组件和局部组件都可以存储数据,但是存储的方式与Vue实例中的data稍有不同;

      组件里存储数据,data后需加上函数,数据写在函数体中

      this is component-a作为局部属性使用

    局部组件:只可以再div id="GaryId"中使用

            <div id="GaryId">
                <my-component-a></my-component-a>
            </div>
                new Vue({
                    data:{
                        msg:'Gary'
                    },
                    components:{
                        "my-component-a":{
                            template:"<h2>this is component-a</h2>"
                        }
                    }
                }).$mount("#GaryId");
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Gary</title>
        </head>
        <body>
            <div id="GaryId">
                <my-component-a></my-component-a>
            </div>
        </body>
        
        <script type="text/javascript" src="../js/vue.js" ></script>
        <script type="text/javascript">
                
                
                new Vue({
                    data:{
                        msg:'Gary'
                    },
                    components:{
                        "my-component-a":{
                            template:"<h2>this is component-a</h2>"
                        }
                    }
                }).$mount("#GaryId");
                
                
                
        </script>
    </html>
    Gary_component-02.html

    全局属性:可以在任意div中调用

            <div id="GaryId">
                <my-component-a></my-component-a>
                <my-component-b></my-component-b>
            </div>
                //注册组件的简写(默认全局)
                Vue.component('my-component-b',{
                    template:"<h2>{{name}}</h2>",
                    data:function(){
                        return {
                            name:'this is component-b'
                        }
                    }
                })
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Gary</title>
        </head>
        <body>
            <div id="GaryId">
                <my-component-a></my-component-a>
                <my-component-b></my-component-b>
            </div>
        </body>
        
        <script type="text/javascript" src="../js/vue.js" ></script>
        <script type="text/javascript">
                
                //注册组件的简写(默认全局)
                Vue.component('my-component-b',{
                    template:"<h2>{{name}}</h2>",
                    data:function(){
                        return {
                            name:'this is component-b'
                        }
                    }
                })
                
                new Vue({
                    data:{
                        msg:'Gary'
                    },
                    components:{
                        "my-component-a":{
                            template:"<h2>this is component-a</h2>"
                        }
                    }
                }).$mount("#GaryId");
                
                
                
        </script>
    </html>
    Gary_component-02.html

    三、this is component-a

      在component的template中书写大量的HTML元素很麻烦

      Vue提供了<template>标签,可以在里边书写HTML,然后通过ID指定到组建内的template属性上;

      <body>标签中调用组件

            <div id="GaryId">
                <my-component-b></my-component-b>
            </div>

      在<template>标签中通过id"my-template"添加组件

            <template id="my-template">
            <div>
                <h2>{{name}}</h2>
                <button @click="count++">{{count}}</button>
                <ul>
                    <li v-for="item in numArray">{{item}}</li>
                </ul>
            </div>
        </template>
    new Vue({
                data : {
                    msg : '123'
                },
                components : {
                    "my-component-b" : {
                        template :  "#my-template",
                        data(){
                            return {
                                name : "my-component-b !!",
                                numArray : [1, 2, 3, 4, 5],
                                count : 0
                            }
                        }
                    }
                }
                }).$mount("#GaryId");

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Gary</title>
        </head>
        <body>
            <div id="GaryId">
                <my-component-b></my-component-b>
            </div>
        </body>
        
            <template id="my-template">
            <div>
                <h2>{{name}}</h2>
                <button @click="count++">{{count}}</button>
                <ul>
                    <li v-for="item in numArray">{{item}}</li>
                </ul>
            </div>
        </template>
        
        <script type="text/javascript" src="../js/vue.js" ></script>
        <script type="text/javascript">
    
            new Vue({
                data : {
                    msg : '123'
                },
                components : {
                    "my-component-b" : {
                        template :  "#my-template",
                        data(){
                            return {
                                name : "my-component-b !!",
                                numArray : [1, 2, 3, 4, 5],
                                count : 0
                            }
                        }
                    }
                }
                }).$mount("#GaryId");
                
        </script>
    </html>
    Gary_component-03.html
    (如需转载学习,请标明出处)
  • 相关阅读:
    vmware中的虚拟系统和真实系统同时上网
    code first实现自关联(树结构数据)
    td无内容如何显示边框
    vs新建模板
    为ashx文件启用session管理
    有效防止SQL注入漏洞
    用DIV建左右自动伸缩型布局
    身份证验证算法
    CSS布局需注意的问题
    使用sharppcap抓数据包
  • 原文地址:https://www.cnblogs.com/1138720556Gary/p/10446719.html
Copyright © 2011-2022 走看看