编写Vue.js组件前需要知道的10件事

本文介绍了编写 Vue.js 组件前需要知道的 10 件事,其中包括:组件可以全局或局部加载;延迟加载 / 异步组件;必需的 Props;使用 $emit 触发自定义事件;多 Props 绑定和覆盖等等。

1. 组件可以全局或局部加载

Vue.js 提供了两种加载组件的方法:一种是 Vue 实例中的全局加载,另一种是组件级的加载。两种方法都有各自的优点。

全局加载的组件可以从应用程序中的任何模板(包括子组件)访问。它限制了将全局组件导入子组件的次数。此外,如果你全局加载组件,就不会得到 Vue 注册组件错误“你注册的组件正确吗?”注意,加载全局组件要谨慎。它会使你的应用程序膨胀,即使不使用,它仍然会包含在你的 Webpack 构建中。

复制代码
     
   
   
   
   
import Vue from 'vue';
import Editor from './componetns/Editor.vue'
//Where 'editor' is the name of the component
Vue.component('editor', Editor);

局部加载组件使你能够隔离组件,并且只在必要时加载它们。当与 Webpack 结合使用时,你可以只在使用组件时延迟加载它们。这使你的应用程序初始文件较小,并减少了初始加载时间。

复制代码
     
   
   
   
   

2. 延迟加载 / 异步组件

使用 Webpack 的动态导入来延迟加载组件。Vue 支持在渲染时延迟加载组件和代码分割。这些优化让你可以只在需要时加载组件代码,从而减少 HTTP 请求、文件大小,并自动提高性能。这个特性的重要之处在于,它既可以处理全局加载的组件,也可以处理局部加载的组件。

全局加载异步组件:

复制代码
     
   
   
   
   
import Vue from 'vue';
//Where 'editor' is the name of the component
//Returns a promise that only gets called when the compoent is rendered and then cached.
Vue.component('editor', () => import('./componetns/Editor.vue'));

本地加载异步组件:

复制代码
     
   
   
   
   

“当他们将平均页面加载时间减少 850 毫秒时,COOK 将转化率提高了 7%,跳出率降低了 7%,每次会话增加了 10%。”

3. 必需的 Props

有很多方法可以为组件创建 props;你可以传递一个表示 prop 名称的字符串数组,也可以传递一个以键作为 prop 名称的对象和一个配置对象。

使用基于对象的方法,你可以为单个 prop 创建一些键配置更改,其中之一就是必需的键。必需的键需要一个 true 或 false 值。当组件被使用时,如果 prop 没有设置,true 就会抛出一个错误,false(默认值)就不必需或者抛出一个错误。在和其他开发人员共享组件以及提醒你自己某个 prop 对该组件至关重要时,这是很好的做法。

复制代码
     
   
   
   
   

4. 使用 $emit 触发自定义事件

子组件和父组件之间的通信可以通过使用组件内置的函数 emit来发出自定义事件。emit来发出自定义事件。emit 函数接受一个事件名称字符串和要发出的可选值。要侦听事件,只需将“@eventName”添加到发出事件的组件并传入事件处理程序。这是一种很好的方法,可以保持真相的单一来源,并使数据从子组件流向父组件。

复制代码
     
   
   
   
   
复制代码
     
   
   
   
   

7. 多 Props 绑定和覆盖

如果组件有许多 props(比如 5、6、7 或更多),那么不断地为每个 prop 设置绑定可能会变得单调乏味。幸运的是,有一种快速的方法可以设置组件上所有属性的绑定,那就是使用 v-bind 绑定对象,而不是单个属性。

使用对象绑定的另一个好处是可以覆盖来自对象的任何绑定。在我们的例子中,如果我们在 person 对象中将 isActive 设置为 false,那么我们就可以对实际的 person 组件执行另一个绑定,并将 isActive 设置为 true,而不覆盖原始组件。

复制代码
     
   
   
   
   

8. 在组件中修改 Props

在某些情况下,你可能希望修改从某个 prop 传入的值。然而,这样做你会收到一个警告“避免直接改变一个 prop”,因为你的确不该。相反,使用 prop 值作为局部数据属性的默认值。这样做将使你能够看到原始值,而修改局部数据不会改变 prop 值。

这是有代价的。使用此方法,你的局部数据属性不会对 prop 值作出反应,因此来自父组件的任何对 prop 值的更改都不会更新你的局部值。但如果确实需要这些更新,则可以使用 computed 属性来组合值。

复制代码
     
   
   
   
   

9. Test Utils Mount 与 Shallow Mount

有两种方法可以在 Vue tests utils 中创建和引导组件。一个是 mount,另一个是 shallow mount;两者各有优缺点。

当你希望在组件及其子组件之间进行共生测试时,mount 技术非常有效。它让你可以测试父组件是否正确地与子组件进行预期的交互。相反,正如名称所示,shallow mount 只实例化父组件并在完全隔离的情况下渲染它,而不考虑它的任何子组件。

那么哪种方法更好呢?这取决于你。你选择的策略应该取决于你自己的可衡量目标。试着在完全隔离的情况下单独测试组件,shallow 方法工作得很好。需要处理包含子组件的组件,而且要确保通信,那么就要使用 mount 选项。一个很好的选择是两者都使用。你并不必局限于一个,以混合搭配满足测试需求为准。

10. 强大的 Vue-cli

Vue CLI 是一个功能强大的命令行界面,它使得开发人员可以快速地利用大量可以加速工作流的特性。

我经常使用的一个特性是运行 vue serve 并将路径传递给 vue 组件。这样做的好处在于,你可以完全独立地开发组件,同时还可以热重载和遍历组件,直到它的核心功能都完成了为止。不需要临时将新组件导入要开发的页面。

vue serve ./components/views/GoldenRule

在团队中工作时,你可能希望提取一个特定的组件并与其他组件共享。这就需要 Vue CLI 的下一个特性:将 Vue 组件导出为库的能力。当被调用时,Vue 将自动构建一个单文件组件,将 CSS 移到一个外部 CSS 文件中(可选的,你也可以内联它),并创建 UMD 和 Common .js 文件,以导入其他 JS 项目。

vue build —-target lib --name goldenRule ./components/views/GoldenRule

英文原文: https://levelup.gitconnected.com/10-things-you-should-know-before-writing-your-next-vuejs-component-4f97964611f4

你可能感兴趣的:(编写Vue.js组件前需要知道的10件事)