Jamey's Jamey's
首页
导航站
  • 学习专栏

    • 《HTML》笔记
    • 《CSS》笔记
    • 《JavaScript》笔记
    • 《Vue》笔记
    • 《Git》笔记
    • 《规范》笔记
    • 《软技能》笔记
    • 《面试》笔记
    • 《持续集成&交付&部署》笔记
  • 踩坑专栏

    • 《Element-UI 实践系列》笔记
    • 《移动端 实践系列》笔记
    • 《综合》笔记
  • 配置专栏

    • 《环境系列》笔记
  • 极空间

    • Docker
  • 影视

    • movie
  • 编辑器笔记

    • 开发编辑器
  • 浏览器笔记

    • Chrome
  • Mac笔记

    • Mac
  • 跨界学习

    • 运营
  • 破解合集

    • 破解
  • 本站

    • 分类
    • 标签
    • 归档
  • 我的

    • 收藏
    • 书单
    • 关于

Jamey

首页
导航站
  • 学习专栏

    • 《HTML》笔记
    • 《CSS》笔记
    • 《JavaScript》笔记
    • 《Vue》笔记
    • 《Git》笔记
    • 《规范》笔记
    • 《软技能》笔记
    • 《面试》笔记
    • 《持续集成&交付&部署》笔记
  • 踩坑专栏

    • 《Element-UI 实践系列》笔记
    • 《移动端 实践系列》笔记
    • 《综合》笔记
  • 配置专栏

    • 《环境系列》笔记
  • 极空间

    • Docker
  • 影视

    • movie
  • 编辑器笔记

    • 开发编辑器
  • 浏览器笔记

    • Chrome
  • Mac笔记

    • Mac
  • 跨界学习

    • 运营
  • 破解合集

    • 破解
  • 本站

    • 分类
    • 标签
    • 归档
  • 我的

    • 收藏
    • 书单
    • 关于
  • 基础

  • 组件

    • 一次性讲明白 Vue 插槽 slot
    • 计算属性怎么传参?
      • 📖. 前言
      • 一. 返回函数
      • 二. filters
      • 🌟. 总结
  • 路由

  • 自定义指令

  • 实践踩坑

  • 知识点

  • 《Vue》笔记
  • 组件
Jamey
2021-11-10
目录

计算属性怎么传参?

# 计算属性怎么传参?

# 📖. 前言

在 Vue 中,计算属性(computed)是从其他响应式属性派生的属性,是用于自动监听响应式属性的变化,从而动态计算返回值。计算属性(computed)通常是一个没有参数的函数。当然如果需要像调用方法一样给计算属性传递参数也是可以的, 本文介绍两种向计算属性传参的方法。

# 一. 返回函数

这种方式通过计算属性返回的函数来进行传参,如下代码片段,对于一条未审核通过的记录,审核时间为 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) : '--');
    },
    // 或者
    // auditTime() {
    //   return function (timestamp) {
    //     /** do something */
    //     if (timestamp > 0) {
    //       return convertDate(timestamp);
    //     }
    //     return '--';
    //   }
    // } 
  },
};
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30

上面代码的计算属性 auditTime,返回一个箭头函数,接收参数 timestamp 为时间戳,函数 convertDate 实现了时间戳时间格式化。

# 二. filters

可以为组件添加一个过滤器 filters,以便可以在模板中按照想要的方式格式化值。

关于 vue 过滤器,在 官方文档 (opens new window) 中定义如下:

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>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

在上面的片段中,当时间戳为 0 的时候输出的是 --。

{{ 1621836603 | auditTime('--') }}
1

上面代码最终显示为:2021-11-10 06:35。

 {{ 0 | auditTime('--') }}
1

# 🌟. 总结

关于计算属性中传参,当然可以在 methods 中定义相应的方法,两者主要区别是:computed 是可以被缓存的,methods 不能缓存。

#Vue.js2
上次更新: 2022/07/01, 17:34:19
一次性讲明白 Vue 插槽 slot
keep-alive 深入理解及实践总结

← 一次性讲明白 Vue 插槽 slot keep-alive 深入理解及实践总结→

Theme by Vdoing | Copyright © 2017-2023 Jamey | blog 闽ICP备19022664号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式