首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Vue $attrs、$listeners 详解及使用

传送门:Vue 子组件向父组件传值 及 .sync 修饰符 详解 传送门:Vue 状态管理器(vuex)详解及应用场景 传送门:Vue 事件总线(eventBus)详解及使用 传送门:Vue... provide、inject 详解及使用 Vue 常见的组件通信方式可分为三类 父子通信 父向子传递数据是通过 props,子向父是通过 events($emit); 通过父链 / 子链也可以通信...Vue 2.4 版本提供了另一种方法,使用 v-bind=”$attrs”, 将父组件不被认为 props 特性绑定的属性传入子组件,通常配合 interitAttrs 选项一起使用。...(简单的说,inheritAttrs:true 继承除 props 之外的所有属性;inheritAttrs:false 只继承 class style 属性) $attrs–继承所有的父组件属性...-- C组件能直接触发test的原因在于 B组件调用C组件时 使用 v-on 绑定了$listeners 属性 --> <child2 v-bind="$attrs" v-on="$listeners

1.2K80

如何构建运行良好的Vue组件

然后我们想在一个不同的项目中使用它,所以我们把它转移到一个独立的包。然后我们想“嘿,为什么不把这个分享给全世界呢?”于是我们开源了这个组件。...为此,我们告诉组件默认情况下不要应用属性,而是直接使用$attrs对象应用它们,在 JS 代码: export default { inheritAttrs: false, } 在模板 <div...import Vue from 'vue'; Vue.component('base-input', { inheritAttrs: false, props: ['label', 'value...此处有两处异常: 父组件设置的placeholder等属性没有传到子组件; 父组件设置的属性传递给了子组件的根元素,即label,而label是不需要的 attrs和inheritAttrs:false...因为 Vue 的自定义事件不会像原生浏览器事件那样冒泡,所以两者在功能上是等效的,但是对于可重用的组件,建议能使用事件就使用事件,其次在再是回调,为什么

3.6K20

vue $attrs的使用

$attrs的使用 vue $attrs是在vue的2.40版本以上添加的。 项目中有多层组件传参可以使用attrs,可以使代码更加美观,更加简洁,维护代码的时候更方便。...),中间层,作为父组件和孙子组件的传递中介,在儿子组件给孙子组件添加v-bind="$attrs",这样孙子组件才能接收到数据 .../GrandChild.vue' export default { // 继承所有父组件的内容 inheritAttrs: true, components: { GrandChild }, data...: false, // 在本组件需要接收从父组件传递过来的数据,注意props里的参数名称不能改变,必须和父组件传递过来的是一样的 props: { isShow: { type: Boolean...版本之后,可以通过inheritAttrs = false 来控制这些特性是否显示在dom元素上 如:案例父组件给子组件传递的row和isShow,子组件没有使用props接收,这个2个数据直接作为HTML

1.3K60

Vue组件间的通信方式浅析

前言 在Vue组件库开发过程Vue组件之间的通信一直是一个重要的话题,虽然官方推出的 Vuex 状态管理方案可以很好的解决组件之间的通信问题,但是在组件库内部使用 Vuex 往往会比较重,本文将系统的罗列出几种不使用...ComponetA 给 ComponetB 传递了三个属性 name、age 和 sex,ComponentB 通过 v-bind=" {age: '24', sex: 'male'} 为什么我们一开始传递了三个属性...说白了就是一句话,**$attrs 可以获取父组件绑定的非 Props 属性**。 一般在使用的时候会同时和 inheritAttrs 属性配合使用。...**如果你不希望组件的根元素继承 attribute,你可以在组件的选项设置 inheritAttrs: false**。...在 ComponentB 添加了 inheritAttrs=false 属性后,ComponentB 的dom结构可以看到是不会继承父组件传递过来的属性: image.png 如果不加上 inheritAttrs

1.6K10

Vue 为什么不推荐用 index 做 key

本文首发于政采云前端团队博客:在 Vue 为什么不推荐用 index 做 key https://zoo.team/article/vue-index 前言 前端开发,只要涉及到列表渲染,那么无论是...那么这篇文章就会讲解 key 的作用以及为什么最好不要使用 index 作为 key 的属性值。...key 的作用 Vue 中使用虚拟 dom 且根据 diff 算法进行新旧 DOM 对比,从而更新真实 dom ,key 是虚拟 DOM 对象的唯一标识, 在 diff 算法 key 起着极其重要的作用...key 在 diff 算法的角色 其实在 React,Vue diff 算法大致是差不多,但是 diff 比对方式还是有较大差异的,甚至每个版本 diff 都大有不同。...下面我们就以 Vue3.0 diff 算法为切入点,剖析 key 在 diff 算法的作用 具体 diff 流程如下 Vue3.0 在 patchChildren 方法中有这么一段源码 if (

1.2K20

Vue data 为什么必须是一个函数

为什么 Vue 的 data 必须是个函数? 官方文档的解释如下: ? ? 为什么会出现上述“影响到其它所有实例”的情况呢?...其实这个问题取决于 JS 原型链知识,而非 Vue 我们先来看不是函数的情况: function Component() { } Component.prototype.data = { name...= new Component() componentA.data.age = 40 console.log(componentA, componentB) // 40 14 这就很好的解释了为什么...Vue 组件的 data 需要用函数了,当 data 是函数的时候,每一个实例的 data 属性都是独立的,互不影响 总结 Vue 的 data 必须是个函数,因为当 data 是函数时,组件实例化的时候这个函数将会被调用...,返回一个对象,计算机会给这个对象分配一个内存地址,实例化几次就分配几个内存地址,他们的地址都不一样,所以每个组件的数据不会相互干扰,改变其中一个组件的状态,其它组件不变 简单来说,就是为了保证组件的独立性和可复用性

1.2K20

vue组件通信6种方式总结(常问知识点)1

前言在Vue组件库开发过程Vue组件之间的通信一直是一个重要的话题,虽然官方推出的 Vuex 状态管理方案可以很好的解决组件之间的通信问题,但是在组件库内部使用 Vuex 往往会比较重,本文将系统的罗列出几种不使用...$attrs 的值为:{age: '24', sex: 'male'}为什么我们一开始传递了三个属性,最后只打印了两个属性 age 和 sex 呢?...说白了就是一句话,$attrs 可以获取父组件绑定的非 Props 属性。一般在使用的时候会同时和 inheritAttrs 属性配合使用。...如果你不希望组件的根元素继承 attribute,你可以在组件的选项设置 inheritAttrs: false。...在 ComponentB 添加了 inheritAttrs=false 属性后,ComponentB 的dom结构可以看到是不会继承父组件传递过来的属性:图片如果不加上 inheritAttrs=false

56030

Vue2.4$attrs和$listeners的使用-学习笔记

使用B来做中转站,当A组件需要把信息传给C组件时,B接受A组件的信息,然后利用属性传给C组件,这是一种解决方案,但是如果嵌套的组件过多,会导致代码繁琐,代码维护比较困难;如果C状态的改变需要传递给A,...在vue2.4,为了解决该需求,引入了attrs 和listeners , 新增了inheritAttrs 选项。...> export default { name:'child-dom' props:["foo"] } 当显示父组件时,查看Dom结构,结构如下 在2.4新增选项...inheritAttrs inheritAttrs的默认值为true, 将inheritAttrs的值设为false, 这些默认的行为会禁止掉。...vue2.4版本新增了listeners 属性,我们在b组件上 绑定 v-on=”listeners”, 在a组件,监听c组件触发的事件。就能把c组件发出的数据,传递给a组件。

88860

一个透传技巧,治好了我的重度代码洁癖

原创@前端司南 背景介绍 透传是一个通讯层面的概念,指的是在通讯不管传输的业务内容如何,只负责将传输的内容由源地址传输到目的地址,而不对业务数据内容做任何改变。...强如框架的设计者尤小右自然早已想到了这个场景,所以你应该在Vue官网文档关注到inheritAttrs[1]。 如何理解inheritAttrs(默认值为true)这个选项呢?...也就是说,inheritAttrs的作用是:使那些没有在props定义的属性,直接以attribute的形式作用在组件的根元素上!...恰好,Vue提供了$attrs[2]用于获取这些属性,而v-bind本身就能绑定一个对象,这是容易被我们忽略的!...参考 [1] inheritAttrs: https://cn.vuejs.org/v2/api/#inheritAttrs [2] $attrs: https://cn.vuejs.org/v2/api

1.1K40

Vue 组件间的通信方式

前言在 Vue 组件库开发过程Vue 组件之间的通信一直是一个重要的话题,虽然官方推出的 Vuex 状态管理方案可以很好的解决组件之间的通信问题,但是在组件库内部使用 Vuex 往往会比较重,本文将系统的罗列出几种不使用...$attrs 的值为:{age: '24', sex: 'male'}复制代码为什么我们一开始传递了三个属性,最后只打印了两个属性 age 和 sex 呢?...说白了就是一句话,$attrs 可以获取父组件绑定的非 Props 属性。一般在使用的时候会同时和 inheritAttrs 属性配合使用。...如果你不希望组件的根元素继承 attribute,你可以在组件的选项设置 inheritAttrs: false。...在 ComponentB 添加了 inheritAttrs=false 属性后,ComponentB 的 dom 结构可以看到是不会继承父组件传递过来的属性:如果不加上 inheritAttrs=false

41020

分享几点关于 Vue 代码可读性的建议

一、善用组件让代码更有条理性 千万不要把一个页面的实现代码都梭哈在一个.vue文件,除非这个页面非常简单,不然这个.vue文件的代码会又长又臭。...这是因为Vue页面渲染更新时不会去更新页面的组件,除非组件的props或者slot所引用的数据发生变化。...或许你想都没想就在组件监听文件成功打开的方法写下收藏逻辑代码,过一段时间后,需求改为要先添加到阅读记录再点击收藏按钮收藏,去组件修改代码时发现另一个页面也引用了这个组件,故在组件要额外加个参数做业务场景区分...选项设置为false,为什么呢,来看一下inheritAttrs选项的定义就明白了。...简单来说,把inheritAttrs设置为false,v-bind="$attrs" 才生效。

1.1K30

3 个简单的技巧让你的 vue.js 代码更优雅!

一、善用组件让代码更有条理性 千万不要把一个页面的实现代码都梭哈在一个.vue文件,除非这个页面非常简单,不然这个.vue文件的代码会又长又臭。...这是因为Vue页面渲染更新时不会去更新页面的组件,除非组件的props或者slot所引用的数据发生变化。...或许你想都没想就在组件监听文件成功打开的方法写下收藏逻辑代码,过一段时间后,需求改为要先添加到阅读记录再点击收藏按钮收藏,去组件修改代码时发现另一个页面也引用了这个组件,故在组件要额外加个参数做业务场景区分...选项设置为false,为什么呢,来看一下inheritAttrs选项的定义就明白了。...简单来说,把inheritAttrs设置为false,v-bind="$attrs" 才生效。

80920
领券