7个有用的Vue开发技巧

栏目: 编程语言 · 发布时间: 5年前

内容简介:随着组件的细化,就会遇到多组件状态共享的情况,如下这个例子,我们将在组件外创建一个首先创建一个 store.js,包含一个

1 状态共享

随着组件的细化,就会遇到多组件状态共享的情况, Vuex 当然可以解决这类问题,不过就像 Vuex 官方文档所说的,如果应用不够大,为避免代码繁琐冗余,最好不要使用它,今天我们介绍的是 vue.js 2.6 新增加的  Observable API ,通过使用这个 api 我们可以应对一些简单的跨组件数据状态共享的情况。

如下这个例子,我们将在组件外创建一个 store ,然后在 App.vue 组件里面使用 store.js 提供的 storemutation 方法,同理其它组件也可以这样使用,从而实现多个组件共享数据状态。

首先创建一个 store.js,包含一个 store 和一个 mutations ,分别用来指向数据和处理方法。

然后在 App.vue 里面引入这个 store.js,在组件里面使用引入的数据和方法

你可以点击 在线DEMO   查看最终效果

2 长列表性能优化

我们应该都知道 vue 会通过 object.defineProperty 对数据进行劫持,来实现视图响应数据的变化,然而有些时候我们的组件就是纯粹的数据展示,不会有任何改变,我们就不需要 vue 来劫持我们的数据,在大量数据展示的情况下,这能够很明显的减少组件初始化的时间,那如何禁止 vue 劫持我们的数据呢?可以通过 object.freeze 方法来冻结一个对象,一旦被冻结的对象就再也不能被修改了。

另外需要说明的是,这里只是冻结了 users 的值,引用不会被冻结,当我们需要 reactive 数据的时候,我们可以重新给 users 赋值。

3 去除多余的样式

随着项目越来越大,书写的不注意,不自然的就会产生一些多余的 css,小项目还好,一旦项目大了以后,多余的 css 会越来越多,导致包越来越大,从而影响项目运行性能,所以有必要在正式环境去除掉这些多余的css,这里推荐一个库 purgecss ,支持 CLI、JavascriptApi、Webpack 等多种方式使用,通过这个库,我们可以很容易的去除掉多余的 css。

我做了一个测试, 在线DEMO

最终产生的 purgecssResult 结果如下,可以看到多余的 aul 标签的样式都没了

evernotecid://15DE25B8-A8A2-48DA-BEA3-2B892B3566BA/appyinxiangcom/22977527/ENResource/p232 7个有用的Vue开发技巧

4 作用域插槽

利用好作用域插槽可以做一些很有意思的事情,比如定义一个基础布局组件A,只负责布局,不管数据逻辑,然后另外定义一个组件B 负责数据处理,布局组件A 需要数据的时候就去 B 里面去取。假设,某一天我们的布局变了,我们只需要去修改组件A 就行,而不用去修改组件B,从而就能充分复用组件B 的数据处理逻辑,关于这块我之前写过一篇实际案例,可以点击 这里 查看。

这里涉及到的一个最重要的点就是父组件要去获取子组件里面的数据,之前是利用 slot-scope ,自 vue 2.6.0 起,提供了更好的支持 slotslot-scope 特性的 API 替代方案。

比如,我们定一个名为 current-user 的组件:

父组件引用 current-user 的组件,但想用名替代姓(老外名字第一个单词是名,后一个单词是姓):

这种方式不会生效,因为 user 对象是子组件的数据,在父组件里面我们获取不到,这个时候我们就可以通过 v-slot 来实现。

首先在子组件里面,将 user 作为一个 <slot> 元素的特性绑定上去:

之后,我们就可以在父组件引用的时候,给 v-slot 带一个值来定义我们提供的插槽 prop 的名字:

这种方式还有缩写语法,可以查看 独占默认插槽的缩写语法 ,最终我们引用的方式如下:

相比之前 slot-scope 代码更清晰,更好理解。

5 属性事件传递

写过高阶组件的童鞋可能都会碰到过将加工过的属性向下传递的情况,如果碰到属性较多时,需要一个个去传递,非常不友好并且费时,有没有一次性传递的呢(比如react里面的 {...this.props} )?答案就是 v-bindv-on

举个例子,假如有一个基础组件 BaseList ,只有基础的列表展示功能,现在我们想在这基础上增加 排序 功能,这个时候我们就可以创建一个高阶组件 SortList

可以看到传递属性和事件的方便性,而不用一个个去传递

6 函数式组件

函数式组件,即无状态,无法实例化,内部没有任何生命周期处理方法,非常轻量,因而渲染性能高,特别适合用来只依赖外部数据传递而变化的组件。

写法如下:

  1. 在  template 标签里面标明  functional

  2. 只接受  props

  3. 不需要  script 标签

7 监听组件的生命周期

比如有父组件 Parent 和子组件 Child ,如果父组件监听到子组件挂载 mounted 就做一些逻辑处理,常规的写法可能如下:

这里提供一种特别简单的方式,子组件不需要任何处理,只需要在父组件引用的时候通过 @hook 来监听即可,代码重写如下:

当然这里不仅仅是可以监听 mounted ,其它的生命周期事件,例如: createdupdated 等都可以,是不是特别方便~

作者:skinnerl 【微店】前端开发工程师 原文:https://juejin.im/post/5ce3b519f265da1bb31c0d5f

7个有用的Vue开发技巧


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

共鸣:内容运营方法论

共鸣:内容运营方法论

舒扬 / 机械工业出版社 / 2017-5-8 / 59.00

近5年来网络信息量增长了近10倍,信息极度过剩。移动互联网以碎片化、强黏度以及惊人的覆盖率给传统的商业环境带来了巨大的影响,向陈旧的广告、公关、媒体行业展开了深度的冲击。 传统的以渠道为中心的传播思想几近失效,优秀内容成为了各行业最稀缺的资产,这是时代赋予内容生产者的巨大机会。本书作者在多年经验和大量案例研究的基础上,总结出了移动互联网时代的内容运营方法论——共鸣,它将告诉我们如何收获核心粉......一起来看看 《共鸣:内容运营方法论》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

SHA 加密
SHA 加密

SHA 加密工具