vue -- 7 个 有用的 Vue 开发技巧

 

 

1 状态共享

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

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

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

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

2 长列表性能优化

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

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

3 去除多余的样式

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

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

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 的名字:

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

5 属性事件传递

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

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

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

6 函数式组件

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

写法如下:

  1. 在 template标签里面标明 functional

  2. 只接受 props

  3. 不需要 script标签

7 监听组件的生命周期

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

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

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

转载于:https://www.cnblogs.com/yuerdong/p/10985348.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 基于Vue开发的组态编辑器已经有很多开源项目可以使用。Vue是一种流行的JavaScript框架,适用于构建现代且高效的用户界面。 组态编辑器是一种可以帮助开发人员和设计师创建和编辑用户界面的工具。它通常提供了一个可视化界面,允许用户拖放和配置各种组件,并生成相应的代码。 通过使用Vue,开源的组态编辑器可以充分利用Vue的特性。Vue的组件化架构使得创建和嵌套组件变得非常容易,这使得组态编辑器可以提供丰富的组件库以及快速配置和编辑的功能。 这些开源的基于Vue的组态编辑器提供了灵活的自定义选项,可以根据用户的需求进行扩展和定制。通过使用Vue的生态系统中的其他工具和库,如Vuex和Vue Router,组态编辑器可以实现更复杂的功能,如状态管理和路由。 开源的组态编辑器项目还提供了强大的社区支持。开发者可以从其他用户的经验中获益,找到解决问题的方法,并与其他人共享自己的成果。 总之,基于Vue开发的开源组态编辑器是一个非常有用的工具,可以帮助开发人员和设计人员更轻松地创建和编辑用户界面。它利用了Vue的特性和生态系统,并通过强大的社区支持提供了一个简单而灵活的解决方案。 ### 回答2: 基于Vue开发的组态编辑器是一种用于创建、编辑和管理可视化组态的开源工具。它是使用Vue框架开发的,通过Vue的响应式数据绑定、组件化和虚拟DOM等特性,具备高效、灵活和可扩展的特点。 作为一个开源项目,基于Vue开发的组态编辑器允许用户自由使用、修改和分发。这意味着用户可以根据自己的需求自定义组态编辑器的功能、扩展其特性,甚至与其他项目进行集成。这种开源的特性使得组态编辑器具有更高的可定制性和可持续性。 基于Vue开发的组态编辑器不仅可以用于创建静态的组态界面,还可以通过各种交互元素(如按钮、输入框等)实现动态的组态效果。它提供了丰富的组件库,包括图表、控件、容器等,用户可以直接拖拽并配置这些组件来构建自己的组态界面。同时,组态编辑器还支持导入、导出组态配置,方便用户在不同项目之间进行共享和迁移。 基于Vue的组态编辑器具有良好的用户界面和用户体验,通过直观的操作和友好的设计,使用户能够轻松地创建、编辑和管理组态界面。它还提供了丰富的文档和示例,帮助用户快速上手并掌握使用技巧。 总之,基于Vue开发的组态编辑器是一个功能丰富、高度可定制和易于使用的开源工具,可以帮助开发者高效地创建和管理可视化组态界面。无论是个人开发者还是企业项目,都可以从中受益并加速开发进程。 ### 回答3: 基于Vue开发的组态编辑器目前是开源的。组态编辑器是一种可帮助用户设计和配置工控系统界面的工具,Vue作为一种流行的JavaScript框架,在开发过程中提供了诸多便利和灵活性。 开源的组态编辑器可以使用户更容易地创建和定制工控系统界面。它提供了一套易于使用和交互友好的界面组件,可以方便地拖拽、缩放和配置,以实现个性化的界面设计。用户可以根据需求自定义各种组件的样式、布局和交互行为。 基于Vue框架的组态编辑器还具备一些高级功能,如数据绑定和响应式设计。它可以与后端服务器进行数据交互,实现动态的数据展示和更新。同时,在用户修改界面配置时,可以实时反映在界面上,减少开发者的调试时间。 由于是开源的,组态编辑器还具备扩展性和可定制性。开发者可以根据自己的需求进行二次开发和定制,添加新的功能或者修改现有功能。同时,开源社区的积极参与也可以提供更多的插件和扩展,丰富组态编辑器的功能。 总的来说,基于Vue开发的组态编辑器具有易用性、灵活性和扩展性等优势。它为用户提供了一种方便快捷的方式来设计和定制工控系统界面,帮助用户实现个性化的界面配置。开源的特性也使得组态编辑器可以更好地适应不同的需求,并获得更多的改进和支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值