您当前的位置: 首页 > 

@大迁世界

暂无认证

  • 1浏览

    0关注

    739博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

将多个属性传递给 Vue 组件的几种方式

@大迁世界 发布时间:2020-04-08 14:35:00 ,浏览量:1

所有使用基于组件的体系结构(如Vue和React)的开发人员都知道,创建可重用组件是很困难的,而且大多数情况下,最终会通过传入大量的属性,以便从外部更容易地控制和自定义组件。这并不坏,但是传递大量属性确实会变得有点麻烦和丑陋。

我们以 vuetify 的按钮组件为例,它是最简单的组件之一。假设我们想要在大多数情况下传递相同的属性:


  Hello Meat

将它们放在单独的文件中是有意义的,这个文件我们取名为props.js

export const buttonProps = {
  color: 'primary',
  small: true,
  outline: true,
  block: true,
  ripple: true,
  href: 'https://alligator.io'
}
JSX 和 render 函数

由于JSX 和 render 函数在渲染时为我们提供了更多的功能和灵活性,所以一次传递多个属性是相当容易的。

在 render 函数中:

import { buttonProps as props } from './props.js';

export default {
  render: h => h(
    'v-btn',
    { props },
    'Hello Meat'
  )
};

在 JSX 中:

import { buttonProps as props } from './props.js';

const data = { props }

export default {
  render: h => Hello Meat
};
使用 Vue.js 模板

使用Vue template怎么样?不用担心,那也是可能的。我们所需要做的就是使用v-bind指令。对于必须在组件的data选项中定义的对象,它将绑定所有属性


  
    Hello Meat
  



  import { buttonProps } from './props.js';

  export default {
    data: () => ({ buttonProps })
  }

使用此技巧,我们无需在应用中的多个位置填充重复属性的模板,同时仍然可以使用受欢迎的模板标记。

总结

使用本文中提到的示例,可以简化将多个属性传递给组件的操作。这对于具有很多属性的表示性和第三方组件特别有用。

注意,这里使用的示例仅仅演示。如果想制作更加灵活可用的,可以根据具体情况使用更好的方法,例如创建自己的包装器组件。

作者:Jover Morales 译者:前端小智  来源:alligator原文:https://alligator.io/vuejs/passing-multiple-properties/

交流

你知道 JS 中的模块导入有一个缺点吗?

纯 CSS 特效,5分钟带你学会制作有个性的滚动条

不要再到处使用 === 了

纯 CSS 特效,5分钟带你学会全屏视频背景滚动淡出

这 10 个技巧让你成为一个更好的 Vue 开发者

这5个 console.log() 技巧帮你提高工作效率

纯 CSS 特效,5分钟带你学会配合视频做好 CSS 特效

关注
打赏
1664287990
查看更多评论
立即登录/注册

微信扫码登录

0.0423s