百科狗-知识改变命运!
--

其他杂项选项 ​

百变鹏仔1年前 (2023-11-21)阅读数 24#技术干货
文章标签组件

其他杂项选项 ​

name ​

用于显式声明组件展示时的名称。

  • 类型

    ts
    interface ComponentOptions { name?: string}
  • 详细信息

    组件的名字有以下用途:

    • 在组件自己的模板中递归引用自己时
    • 在 Vue 开发者工具中的组件树显示时
    • 在组件抛出的警告追踪栈信息中显示时

    当你在使用单文件组件时,组件已经会根据其文件名推导出其名称。举例来说,一个名为 MyComponent.vue 的文件会推导出显示名称为“MyComponent”。

    另一种场景是当一个组件通过 app.component 被全局注册时,这个全局 ID 就自动被设为了其名称。

    使用 name 选项使你可以覆盖推导出的名称,或是在没有推导出名字时显式提供一个。(例如没有使用构建工具时,或是一个内联的非 SFC 式的组件)

    有一种场景下 name 必须是已显式声明的:即 通过其 include / exclude prop 来匹配其需要缓存的组件时。

    TIP

    在 3.2.34 或以上的版本中,使用 的单文件组件会自动根据文件名生成对应的 name 选项,即使是在配合 使用时也无需再手动声明。

inheritAttrs ​

用于控制是否启用默认的组件 attribute 透传行为。

  • 类型

    ts
    interface ComponentOptions { inheritAttrs?: boolean // 默认值:true}
  • 详细信息

    默认情况下,父组件传递的,但没有被子组件解析为 props 的 attributes 绑定会被“透传”。这意味着当我们有一个单根节点的子组件时,这些绑定会被作为一个常规的 HTML attribute 应用在子组件的根节点元素上。当你编写的组件想要在一个目标元素或其他组件外面包一层时,可能并不期望这样的行为。我们可以通过设置 inheritAttrsfalse 来禁用这个默认行为。这些 attributes 可以通过 $attrs 这个实例属性来访问,并且可以通过 v-bind 来显式绑定在一个非根节点的元素上。

  • 示例

    vue
    export default { inheritAttrs: false, props: ['label', 'value'], emits: ['input']}  {{ label }}  

    在一个使用了 的组件中声明这个选项时,可以使用 defineOptions 宏:

    vue
    defineProps(['label', 'value'])defineEmits(['input'])defineOptions({ inheritAttrs: false})  {{ label }}  

    从 3.3 开始你也可以直接在 中使用 defineOptions

    vue
    defineProps(['label', 'value'])defineEmits(['input'])defineOptions({ inheritAttrs: false })  {{ label }}  
  • 参考透传 attribute

components ​

其他杂项选项 ​

一个对象,用于注册对当前组件实例可用的组件。

  • 类型

    ts
    interface ComponentOptions { components?: { [key: string]: Component }}
  • 示例

    js
    import Foo from './Foo.vue'import Bar from './Bar.vue'export default { components: { // 简写 Foo, // 注册为一个不同的名称 RenamedBar: Bar }}
  • 参考组件注册

directives ​

一个对象,用于注册对当前组件实例可用的指令。

  • 类型

    ts
    interface ComponentOptions { directives?: { [key: string]: Directive }}
  • 示例

    js
    export default { directives: { // 在模板中启用 v-focus focus: { mounted(el) { el.focus() } } }}
    template

    这个列表中的指令都在当前组件实例中可用。

  • 参考自定义指令

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)