为什么 Vue 中还存在 InheritAttrs ?

在 Vue 中,我们有inheritAttrs组件选项,当未在组件实例上false声明时,将阻止绑定作为属性应用到 DOM 。props

例如,考虑一下:

<some-component :article="article" />

设置inheritAttrstrue(默认):

<div article="[object Object]"></div>

inheritAttrs设置为false

<div></div>

我试图理解 a) 为什么这是true默认的?b)它为什么存在?

在 DOM 中允许自定义属性会鼓励经验不足的工程师生成无效的 HTML,从而导致代码质量低劣。然而,我倾向于相信 Vue 工程师的经验,因此得出的结论是,它实际上在我尚未遇到的某些场景中很有用。如果在某些用例中这是可以的,那么我想知道,如果没有,那么它到底为什么存在?

另外,有没有办法全局设置呢?我尝试了以下方法(不起作用):

Vue.config.inheritAttrs = false;


翻过高山走不出你
浏览 105回答 2
2回答

www说

它与自定义 HTML 属性无关。不管与否,你都可以这样做inheritAttrs。当您编写包装现有 HTML 元素的组件时,这是一种很有价值的机制。如果没有这个,您将需要在顶部元素中一一绑定每个属性。它更多的是一种便利,而不是必要的功能。

弑天下

默认情况下,您可以使用全局 mixin 对所有组件禁用此选项:Vue.mixin({&nbsp;inheritAttrs:&nbsp;false&nbsp;})如果您需要继承特定组件的属性,显式添加inheritAttrs: true将覆盖全局 mixin 配置。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Html5