网站首页 > 技术文章 正文
在 Vue 中,计算属性(computed )是从其他响应式属性派生的属性,是用于自动监听响应式属性的变化,从而动态计算返回值。计算属性(computed )通常是一个没有参数的函数。当然如果需要像调用方法一样给计算属性传递参数也是可以的,本文介绍两种向计算属性传参的方法。
1.返回函数
这种方式通过计算属性返回的函数来进行传参,如下代码片段,对于一条未审核通过的记录,审核时间为 0,这是显示 -- :
<template>
<div id="app">
<p>
<label>审核时间:</label>
<i class="number">
{{ auditTime(1624314956) }}
</i>
</p>
</div>
</template>
<script>
export default {
computed: {
auditTime: () => {
return (timestamp) => (timestamp > 0 ? convertDate(timestamp) : "--");
},
},
};
</script>
上面代码的计算属性 auditTime,返回一个箭头函数,接收参数timestamp为时间戳,函数 convertDate 实现了时间戳时间格式化。
2.filters
可以为组件添加一个过滤器 filters,以便可以在模板中按照想要的方式格式化值。
关于 vue 过滤器,在官方文档中定义如下:
Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind 表达式(后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示。
<template>
<div id="app">
<p>
<label>审核时间:</label>
<i class="number">
{{ 1624314956 | auditTime("--") }}
</i>
</p>
</div>
</template>
<script>
export default {
filters: {
auditTime: (timestamp, defaultValue = "--") =>
timestamp > 0 ? convertDate(timestamp) : defaultValue,
},
};
</script>
在上面的片段中,当时间戳为0的时候输出的是 -- ,这个格式是否有种似曾相识的感觉,在《Angular管道PIPE介绍》中介绍的管道,方式类似。
{{ 1621836603 | auditTime("--") }}
上面代码最终显示为:2021-06-22 06:35。
{{ 0 | auditTime("--") }}
上面代码最终显示为:--。
总结
关于计算属性中传参,当然可以在 methods 中定义相应的方法,两者主要区别是:computed 是可以被缓存的,methods 不能缓存。
猜你喜欢
- 2025-05-03 VUE3前端开发入门系列教程二:使用iView框架辅助开发
- 2025-05-03 突发!Vue3 投屏神器引爆程序员朋友圈
- 2025-05-03 vue3+vite2开发的开源中后台前端框架——Vben
- 2025-05-03 Spring Boot + Vue.js 实现前后端分离(附源码)
- 2025-05-03 基于若依框架的芋道系统(前端基于vue3+ts)开发环境搭建
- 2025-05-03 Vue.js、React、Angular前端框架,哪个才是做医疗触控屏最佳选择
- 2025-05-03 【推荐】一个基于 SpringBoot + Vue 前后端分离的人力资源管理系统
- 2025-05-03 分享15个基于Vue3.0全家桶的优秀开源项目
- 2025-05-03 令人眼前一亮的vue+vite4+element-plus前端框架
- 2024-09-14 基于Vue2.x的前端架构,我们是这么做的
你 发表评论:
欢迎- 06-24发现一款开源宝藏级工作流低代码快速开发平台
- 06-24程序员危险了,这是一个 无代码平台+AI+code做项目的案例
- 06-24一款全新的工作流,低代码快速开发平台
- 06-24如何用好AI,改造自己的设计工作流?
- 06-24濮阳网站开发(濮阳网站建设)
- 06-24AI 如何重塑前端开发,我们该如何适应
- 06-24应届生靠这个Java简历模板拿下了5个offer
- 06-24服务端性能测试实战3-性能测试脚本开发
- 567℃几个Oracle空值处理函数 oracle处理null值的函数
- 566℃Oracle分析函数之Lag和Lead()使用
- 550℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 546℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 545℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 537℃【数据统计分析】详解Oracle分组函数之CUBE
- 527℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 519℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)