博客
关于我
VUE计算属性computed的get和set / 过滤 /存储数据
阅读量:778 次
发布时间:2019-03-24

本文共 1752 字,大约阅读时间需要 5 分钟。

computed计算属性与数据处理优化

在Vue.js开发中,computed属性是解耦双向绑定核心逻辑的一种强大工具。本文将从computed属性的基本用法、数组操作到数据持久化等方面进行详细讲解。

一、computed计算属性

computed属性允许我们将商业逻辑与视图层解耦,使代码结构更加清晰。通过定义getter和setter,computed属性能够实时反映数据改变,或者根据逻辑计算出的值来控制前后端数据的变化。

一个经典的使用场景是复杂的筛选条件。比如:

我们可以通过computed属性来实现全选/全不选功能:

computed: {    checkAllBox: {        get() {            return this.listsSize === this.lists.length && this.listsSize > 0;        },        set(value) {            this.checkList(value);        }    }}

这段代码中,get函数根据选中的状态来判断是否全部选择,set函数则根据选中的状态调用checkList方法来改变数据。这种设计模式能够显著简化视图层的逻辑式,但仍需注意computed属性较为依赖于数据的深度监视,避免频繁触发依赖解析过程。

二、过滤与删除数组元素

在前一个示例中提到的基础上,我们需要实现删除被选中的数据的功能。可以通过以下方法实现:

cripple 
data() { return { lists: [ { title: '一', complain: false }, { title: '二', complain: false }, { title: '三', complain: true } ] }; }, deleteComplain() { // 定义过滤器,删除状态为false的选项 this.lists = this.lists.filter( list => list.complain === false ); // 调用该方法 this.deleteComplain(); }

通过filter方法,可以轻松地在数据绑定内 اصلاح数组状态,确保视图与状态保持一致。

三、计算被选中的数量

计算被选中的问题,可以通过reduce方法高效实现:

listsSize() {     // 统计状态为true的数据总数     return this.lists.reduce( (preTotal, list) => preTotal + (list.complain ? 1 : 0), 0 ); }

该方法简洁且高效,直接暴露在组件 层,且无需额外依赖安装。

四、数据持久化与脱耦

为了实现数据持久化,我们可以使用localStorage。这种方式适用于需要在不同页面间数据持久化的情况。

1、读取数据

localStorage.getItem('todos_key')

注意:如果第一次存储前未初始化,需设置默认值:

localStorage.getItem('todos_key') || '[]'

2、使用JSON.parse转换

const data = JSON.parse(localStorage.getItem('todos_key') || '[]');

这样处理后,即使存储结果为null,也可以正确解析为数组初始值。

3、深度监视

为了确保数据更新到localStorage,我们需要使用Vue的depth监视:

this.$watch('lists', {    deep: true,    handler(value) {        localStorage.setItem('todos_key', JSON.stringify(value));    } });

这种实现方式的效率很高,只在数据发生改变时触发存储操作。

转载地址:http://hsrkk.baihongyu.com/

你可能感兴趣的文章
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
【Flink】Flink 1.9 版本 web UI 突然没有日志
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>