• Vue(二)


    组件

    组件:html , css , js的集合体,为该集合体命名,用该名字复用html , css , js组成的集合体

    组件的特点:

    1. 组件都有管理组件html页面结果的template实例成员,template中有且只有一个根标签'

      1. 根组件都是作为最顶级父组件,局部与全局组件作为子组件,也可以成为其他局部与全局组件的父组件
      2. 子组件的数据需要隔离(数据组件化,每一个组件拥有自己数据的独立名称空间)
      3. 局部组件必须注册后才能使用,全局组件不需要注册,提倡使用局部组件
      4. 组件中出现的所有变量(模板中,逻辑中),由该组件自己提供管理
      5. 局部全局和根组件都是一个vue实例,一个实例对应一套html , css , js结构,所以实例就是组件

    根组件

    根组件 : new Vue() 生成的组件

    ​ 根组件可以不明确template,template默认采用挂载点页面结构

    如果设置了template,挂载点内部的内容无效,因为会被替换

    <body>
        <div id="app">
            {{ msg }}
        </div>
    </body>
    <script src="js/vue.js"></script>
    <script>
        new Vue({
            el: '#app',  // 被组件 template 模块进行替换的占位符
            data: {
                msg: '组件信息'
            },
        })
    </script>
    

    全局组件

    全局组件 : Vie.component('组件名',{})

    ​ {}内部采用的是vue语法

    <script>
    	Vue.component('global-tag', {
            template: `
            <div class="box" @click="fn">
                <img src="img/002.jpg" alt="">
                <h2>大长腿</h2>
            </div>
            `,
            methods: {
                fn() {
                    console.log(this)
                }
            }
        });
    </script>
    

    局部组件

    局部组件 : {},内部采用的是vue语法

    '''
    声明局部组件,局部组件要在其父组件中注册之后才能使用
    步骤:
    	1. 声明组件
    	2. 注册组件(在根组件的component中注册)
    	3. 渲染组件
    '''
    <script>
        let localTag = {
            template: `
            <div class="box" @click="fn">
                <img src="img/001.jpg" alt="">
                <h2>美女</h2>
            </div>
            `,
            methods: {
                fn() {
                    console.log(this)
                }
            }
        };
        new Vue({
            el: '#app',
            data: {},
            components: {  // 注册组件
                localTag,
            }
        })
    </script>
    

    组件化

    '''
    当复用组件时,使用的数据都是同一个,如果需要将数据隔离
    可以使用类似Python中函数的思想,
    将数据通过函数返回的方式,使每个组件都有自己独立的名称空间,从而使得数据隔离
    '''
    <script>
        let localTag = {
            template: `
            <div class="box" @click="fn">
                <img src="img/001.jpg" alt="">
                <h2>捶了美女{{ count }}下</h2>
            </div>
            `,
            data() {  // 局部或全局取件,一个组件可能会被复用多次,每个组件都应该有自己独立的变量名称空间
                return {
                    count: 0,
                }
            }, // 数据需要组件化,作为方法的返回值(方法执行后会产生一个局部作用域)
            methods: {
                fn() {
                    console.log(this);
                    this.count++;
                }
            }
        };
    
        new Vue({
            el: '#app',
            data: {},
            components: {
                localTag,
            }
        });
    
    </script>
    

    父组件传递数据给子组件

    '''
    1. 子组件可以通过props自定义组件属性
    	(采用反射机制,需要填写字符串,但是使用时可以直接作为变量)
    2. 子组件会在父组件中渲染,渲染时,将父组件的变量绑定给子组件的自定义属性,可以将变量传递给子组件
    '''
    <body>
    <div id="app">
        <div class="wrap">
            <local-tag v-for="dog in dogs" :dog="dog"></local-tag>
        </div>
    </div>
    </body>
    <script>
        let dogs = [
            {
                name: '二哈1号',
                img: 'img/100.jpg',
            },
            {
                name: '二哈2号',
                img: 'img/200.jpg',
            },
            {
                name: '二哈3号',
                img: 'img/300.jpg',
            },
            {
                name: '二哈4号',
                img: 'img/400.jpg',
            },
         ];
    
        let localTag = {
            props:['dog'],
            template: `
            <div class="box" @click="fn">
                <img :src="dog.img" alt="">
                <h2>戳{{dog.name}}{{count}}下</h2>
            </div>
            `,
            data(){
              return{
                  count:0,
              }
            },
            methods: {
                fn() {
                    this.count++
                }
            }
        };
    
        new Vue({
            el: '#app',
            data: {
                dogs,
            },
            components: {  // 注册组件
                localTag,
            }
        })
    </script>
    

    子组件传递数据给父组件

    '''
    自定义事件是属于子组件的,子组件在父组件中渲染并绑定事件方法,所以事件方法由父组件来实现
    
    子组件如何触发自定义事件:
    	this.$emit('自定义事件名', 触发事件回调的参数们)
    
    子组件触发自定义事件,携带出子组件的内容,在父组件中实现自定义事件的方法,拿到子组件传递给父组件的消息
    
    '''
    <!DOCTYPE html>
    <html lang="zh">
    <head>
        <meta charset="UTF-8">
        <title>子传父</title>
    </head>
    <body>
        <div id="app">
            <h1>{{ h1 }}</h1>
            <h3>{{ h3 }}</h3>
            <tag @action="actionFn"></tag>
            <hr>
            <tag2 @h1a="aFn1" @h3a="aFn3"></tag2>
        </div>
    </body>
    <script src="js/vue.js"></script>
    <script>
        let tag = {
            template: `
            <div>
                <input type="text" v-model="t1">
                <input type="text" v-model="t2">
                <button @click="changeTitle">修改标题</button>
            </div>
            `,
            data() {
                return {
                    t1: '',
                    t2: '',
                }
            },
            methods: {
                changeTitle() {
                    if (this.t1 && this.t2) {
                        // console.log(this.t1, this.t2);
                        this.$emit('action', this.t1, this.t2);
                        this.t1 = '';
                        this.t2 = '';
                    }
                }
            }
        };
    
    
        let tag2 = {
            template: `
            <div>
                主标题内容:<input type="text" v-model="t1" @input="t1Fn">
                子标题内容:<input type="text" v-model="t2">
            </div>
            `,
            data() {
                return {
                    t1: '',
                    t2: '',
                }
            },
            methods: {
                t1Fn() {
                    this.$emit('h1a', this.t1);
                },
            },
            watch: {
                t2 () {
                    this.$emit('h3a', this.t2);
                }
            }
        };
    
        new Vue({
            el: '#app',
            data: {
                h1: '主标题',
                h3: '子标题'
            },
            components: {
                tag,
                tag2,
            },
            methods: {
                actionFn(a, b, c) {
                    // console.log('触发了', a, b, c);
                    this.h1 = a;
                    this.h3 = b;
                },
                aFn1(a) {
                    if (!a) {
                        this.h1 = '主标题';
                        return;
                    }
                    this.h1 = a;
                },
                aFn3(a) {
                    if (!a) {
                        this.h3 = '子标题';
                        return;
                    }
                    this.h3 = a;
                },
            }
        })
    </script>
    </html>
    
  • 相关阅读:
    【转载】Allegro Auto Rename器件反标注教程
    FPGA代码设计规范整理
    Cadence Allegro导网表的错误问题解决
    简单玩转Excel排序、筛选、分类汇总与数据透视表功能!
    zt一篇教会你写90%的shell脚本
    zt一篇教会你写90%的shell脚本
    TCP协议理解
    zt 改进TCP,阿里提出高速云网络拥塞控制协议HPCC
    zt TCP的困境与解决方案
    ztGoogle's BBR拥塞控制算法如何对抗丢包
  • 原文地址:https://www.cnblogs.com/samoo/p/12070017.html
Copyright © 2020-2023  润新知