zoukankan      html  css  js  c++  java
  • 7. Vue

    一、组件分类

    1. 定义

    ​ 组件是可以扩展HTML元素,封装可重用的代码。在较高层面上,组件是自定义元素。特点为:代码重用,提高开发效率,让网页结构更清晰。

    2. 局部组件

    ​ 只能在定义它的el中使用,不能在其他位置使用,否则就无法生效。

    3. 全局组件

    ​ 可以在页面中的任何位置使用。

    二、组件的使用

    1. 局部组件

    2. 全局组件

    3. 父子传值

    • 在组件中,通过props声明需要被传递的参数
    • 在父组件中,通过v-bind:变量名 = '变量' 传递数据

    4. 子父传值

    抛出时间的时间不推荐直接在组件里修改根实例的数据

    • 子组件中通过 $emit('自定义事件名')向外抛出自定义事件
    • 父组件中通过 v-on:自定义事件名=动作函数 监听子组件抛出的事件

    注意:事件“addnum”在组件中发出,但处理程序注册为“addNum”。请注意,HTML属性不区分大小写,并且在使用in-DOM模板时不能使用v-on来侦听camelCase事件。您应该使用“add-num”而不是“addNum”。

    5. 组件传值

    ​ 实现点击组件B按钮,让组件A的值自增;子组件1 -> 子组件2

    • (1)在组件1中通过公用的Vue对 bus 抛出自定义事件 bus.$emit('自定义事件', 数据)

    • 在子组件2中 mounted 方法给bus绑定事件 bus.$on('自定义事件', (val)=>{...})

    (1) 领地代码
    <div id="app">
        <my-alex></my-alex>
        <hr>
        <my-mjj></my-mjj>
    </div>
    
    (2) 组件代码
    <script>
        // 借助一个空的Vue对象实现组件间通信
        let bus = new Vue();   // 大项目用这个VueX
        let A = {
            template: `
                <div>
                    <h1>这是 子组件: my-alex </h1>
                    <p>my-mjj被选中的次数:{{ num }}</p>
                </div>
            `,
            data() {
                return {
                    num: 0
                }
            },
            mounted(){
                // 在文档准备就绪之后就要开始监听bus是否触发了 xuanwo 的事件
                /*
                bus.$on('xuanwo', function (val) {
                    // this.num += 1;  // ?
                    console.log(val);
                    console.log(this);  // this 并不是组件A
                })
                */
                // on第一个参数是自定义事件名;第二个参数是回调函数
                bus.$on('xuanwo', (val)=> {
                    // this.num += 1;  // ?
                    console.log(val);
                    console.log(this);  // this 是组件A
                    this.num = val;
                })
            }
        };
    
        let B = {
            template: `
                <div>
                    <h1>这是 子组件: my-mjj </h1>
                    <button v-on:click="add">选我</button>
                </div>
            `,
            data(){
                return {
                    num: 0
                }
            },
            methods: {
                add(){
                    this.num += 1;
                    // 利用bus对象抛出一个自定义事件
                    bus.$emit('xuanwo', this.num);
                }
            }
        };
    
        let app = new Vue({
            el: '#app',
            data: {
                totalNum: 0
            },
            components: {
                'my-alex': A,
                'my-mjj': B
            }
        })
    </script>
    
  • 相关阅读:
    书签
    身份证查询
    Swiper 中文API手册(share)
    seo查询命令
    前端开发薪资之各地区对比(图文分析)(share)
    新浪微博AppKey大集合(share)
    PHP乱码问题,UTF-8(乱码) (share)
    JavaScript 获取数组中最大值、最小值
    设为首页 添加到收藏夹 (share)
    javascript数组 去重
  • 原文地址:https://www.cnblogs.com/hq82/p/11491407.html
Copyright © 2011-2022 走看看