vue $listeners $attr_vue query

vue $listeners $attr_vue query1、vm.$attrs2.4.0新增类型{[key:string]:string}只读详细包含了父作用域中不作为prop被识别(且获取)的特性绑定(class和style除外)。当一个组件没有声明任何prop时,这里会包含所有父作用域的绑定(class和style除外),并且可以通过v-bind=”$attrs”传入内部组件——在创建高级别的组件时非常有用。简单点讲就是包含了所有父组件在子组件上设置的属性(除了prop传递的属性、class和styl

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1、vm.$attrs
  • 2.4.0新增
  • 类型 { [key: string]: string }
  • 只读
  • 详细
    包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class 和 style 除外)。当一个组件没有声明任何prop 时,这里会包含所有父作用域的绑定 (class 和 style 除外),并且可以通过 v-bind=”$attrs” 传入内部组件——在创建高级别的组件时非常有用。
    简单点讲就是包含了所有父组件在子组件上设置的属性(除了prop传递的属性、class 和 style )。
   <div id="app">
      <base-input
        label="姓名"
        class="name-input"
        placeholder="请输入姓名"
        test-attrs="$attrs"
      ></base-input>
    </div>
      Vue.component("base-input", { 
   
        inheritAttrs: true, //此处设置禁用继承特性
        props: ["label"],
        template: ` <label> { 
    {label}}- { 
    {$attrs.placeholder}}- <input v-bind="$attrs"/> </label> `,
        mounted: function() { 
   
          console.log(this.$attrs);
        }
      });
      const app = new Vue({ 
   
        el: "#app"
      });

打印结果
在生命周期方法mounted中打印$attrs,显示除了class和props定义的属性之外的其他属性。
通过 v-bind=”$attrs” 传入子组件内部的input标签
在这里插入图片描述

2、 vm.$listeners
  • 2.4.0新增
  • 类型 { [key: string]: Function | Array }
  • 只读
  • 详细
    包含了父作用域中的 (不含 .native 修饰器的) v-on 事件监听器。它可以通过 v-on=”$listeners” 传入内部组件——在创建更高层次的组件时非常有用。
    简单点讲它是一个对象,里面包含了作用在这个组件上所有的监听器(监听事件),可以通过 v-on=”$listeners” 将事件监听指向这个组件内的子元素(包括内部的子组件)。
    为了查看方便,我们设置inheritAttrs: true,后面补充一下inheritAttrs。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>arrs与listeners</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <child1 :a-child1="aChild1" :a-child2="aChild2" name1="组件1" name2="组件2" attrs='attrs' @test1="test1" @test2="test2"></child1>
    </div>
    <!-- 主要是理解$attrs与$listeners这两个属性-->
    <script>
        Vue.component('child1',{ 
   
            inheritAttrs: true,
            props:['a-child1'],
            mounted(){ 
   
                console.log(this.$attrs);
                console.log(this.$listeners);
            },
            methods:{ 
   
               test1(){ 
   
                this.$emit('test1')
               }
            },
            template:`<div>{ 
    {$attrs.name1}}:{ 
    {aChild1}}</br> attrs:{ 
    {this.$attrs}}</br><button @click="test1">test1</button><child2 v-on="$listeners" v-bind='$attrs'></child2></div>`
        });
        Vue.component('child2',{ 
   
            inheritAttrs: true,
            props:['a-child2'],
            mounted(){ 
   
                console.log(this.$attrs);
                console.log(this.$listeners);
            },
            template:`<div>{ 
    {$attrs.name2}}:{ 
    {aChild2}}</br> attrs:{ 
    {this.$attrs}}</br> <button @click='$listeners.test2'>test2</button></div>`
        });
        var app = new Vue({ 
   
            el:"#app",
            data:{ 
   
                aChild1:'加油',
                aChild2:'努力',
            },
            methods:{ 
   
                test1(){ 
   
                    console.log('child1---')
                },
                test2(){ 
   
                    console.log('child2---')
                }
            }
        });
    </script>
</body>
</html>

上例中,父组件在child1组件中设置两个监听事件test1和test2,分别在child1组件和child1组件内部的child2组件中执行。还设置了三个属性aChild1、aChild2、name1、name2、attrs。其中aChild1、aChild2被对应的组件的prop识别。所以:
child1组件中$attrs为{ “a-child2”: “努力”, “name1”: “组件1”, “name2”: “组件2”, “attrs”: “attrs” };
child2组件中$attrs为{ “name1”: “组件1”, “name2”: “组件2”, “attrs”: “attrs” }
效果如下图:

vue $listeners $attr_vue query child1组件中的\$attrs和\$listeners打印的内容,其中\$attrs不包括通过自身组件中设置的props传进来的值。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/2020062617420676.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3hpYW9saW5saWZl,size_16,color_FFFFFF,t_70#pic_center)

child2组件中的$attrs和$listeners打印的内容
在这里插入图片描述

3、inheritAttrs
  • 2.4.0新增
  • 类型 boolean
  • 默认值:true
  • 详细
    默认情况下父作用域的不被认作 props 的特性绑定 (attribute bindings) 将会“回退”且作为普通的 HTML
    特性应用在子组件的根元素上。当撰写包裹一个目标元素或另一个组件的组件时,这可能不会总是符合预期行为。通过设置 inheritAttrs 到false,这些默认行为将会被去掉。而通过 (同样是 2.4 新增的) 实例属性 $attrs 可以让这些特性生效,且可以通过v-bind 显性的绑定到非根元素上。inheritAttrs设置为false,不影响$attrs,子组件通过$attrs依然可以获取到父组件传过来的属性值。
注意:这个选项不影响 class 和 style 绑定

vm.$listeners的案例如果 inheritAttrs设置为false,html显示如下:

vue $listeners $attr_vue query

如果inheritAttrs设置为true,html显示如下:
vue $listeners $attr_vue query

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/183676.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Vue单页面应用

    Vue单页面应用总结如下: 单页面应用指一个系统只加载一次资源,然后下面的操作交互、数据交互是通过router、ajax来进    行,页面并没有刷新;&lt;1&gt;在vue搭建的环境里面怎么有没有公用的css和js?如果有是怎么引用的?   有公用的css和js,有两种引用的方法:(要深刻理解单页面应用程序哦,单页面就是引入后在哪里都能使用)   1.全局公共引用样式和js文件   …

  • linux下lighttpdserver的具体安装步骤 以及对flv流媒体的支持配置[通俗易懂]

    linux下lighttpdserver的具体安装步骤 以及对flv流媒体的支持配置

  • pycharm字体变大快捷键_调整字体大小在哪里

    pycharm字体变大快捷键_调整字体大小在哪里在PyCharm的中文界面中,如何自定义热键,调整代码编辑界面的字体大小。进入PyCharm》文件》设置》键盘映射在键盘映射界面内的搜索框,搜索“字体”》找到‘增大字体’并双击》点击‘添加鼠标快捷键’然后看见有界面弹出后,直接按住‘Ctrl键、滑动滚轮向上’放大字体快捷键设置好后,缩小字体同理。字体放大和缩小都设置好后,记得应用+确定回到代码编辑界面,发现已经可以通过Ctrl+滚动滚动鼠标来控制字体大小。最后就可以快乐的敲代码了。…

  • Python系列文章索引

    >>>importthisTheZenofPython,byTimPetersBeautifulisbetterthanugly.Explicitis

    2021年12月30日
  • file_get_contents(“php://input”)[通俗易懂]

    file_get_contents(“php://input”)

  • fgc java_内存紧张,FGC停不下来[通俗易懂]

    fgc java_内存紧张,FGC停不下来[通俗易懂]客套话不说了哈,请社区里各路高人,指点以下,有点奔溃了。问题是这样:存储的是监控相关数据。日均7.5亿条数据,副本数1.算上副本,日均新增数据1.8T,只保存2天。查询入口只有UI点击,日pv在100以内(都是有问题才会去看监控)关键是有18台物理机,128G内存,单机双节点。每个节点Heap31G。只能跑一天到2天。。ES版本:1.7.1GC配置比较简单:G1,pause200ms…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号