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)
blank

相关推荐

  • 适配器模式的分析、结构图及基本代码「建议收藏」

    适配器模式的分析、结构图及基本代码

  • 常见的多种在线代码编辑器[通俗易懂]

    常见的多种在线代码编辑器[通俗易懂]1、BeautifyTools提供各种转化工具,但是不会提供前端代码运行的结果。如图,这个编辑器提供的是转化工具,代码提示,错误提示功能很强大,就是没有执行结果。主要功能全部是转化工具。2、codepen可以编辑前端html、css、js代码并查看执行结果,也可以指定其它的编程语言。编辑代码时没有代码提示,错误提示也只有css代码会出现。3、jsbin提供基本的…

  • 电力-104规约实际测试1「建议收藏」

    电力-104规约实际测试1「建议收藏」104规约实际测试

  • 软件概要设计与详细设计

    (一)概要设计的任务与步骤1、总体设计的必要性:可以站在全局角度上,花较少成本,从抽象的层次上分析对比多种可能性的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。2、总体设计的两个阶段:(1)系统设计阶段:确定系统的具体实现方案(2)结构设计阶段:确定软件结构。3、总体设计的9个步骤:(1)设想供选择的方案(2)选取…

  • SCTP协议详解

    SCTP(StreamControlTransmissionProtocol)是一种传输协议,在TCP/IP协议栈中所处的位置和TCP、UDP类似,兼有TCP/UDP两者特征。SCTP是可以确保数据传输的,和TCP类似,也是通过确认机制来实现的。和TCP不同的是:1. TCP是以字节为单位传输的,SCTP是以数据块为单位传输的TCP接收端确认的是收到的字节数,SCTP接收端确认的是接收到的…

发表回复

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

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