乐趣区

关于vue.js:带你掌握Vue过滤器filters及时间戳转换

摘要:Vue 的 filters 过滤器是比拟常见的一个知识点,上面我将联合工夫戳转换的例子带你疾速理解 filters 的用法。

本文分享自华为云社区《三分钟把握 Vue 过滤器 filters 及工夫戳转换》,作者:北极光之夜。。

一. 速识概念:

大家好呀,Vue 的 filters 过滤器是比拟常见的一个知识点,上面我将联合工夫戳转换的例子带你疾速理解 filters 的用法~

依照官网的活来说,Vue.js 容许你自定义过滤器,可被用于一些常见的文本格式化。过滤器能够用在两个中央:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始反对)。过滤器应该被增加在 JavaScript 表达式的尾部,由“管道”符号批示。

简略来说就是在 filters 过滤器里定义一个处理函数,把函数名称写在管道符“|”前面,它就会解决管道符“|”前自定义的数据,其中自定义的数据会主动成为过滤器函数的参数。

<!-- 在双花括号中 -->
{{message | capitalize}}

<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>

过滤器次要能够分为部分过滤器和全局过滤器,上面看具体介绍。

二. 部分过滤器:

  1. 部分过滤器就是在一个组件的选项中定义本地的过滤器,只有该组件能够用。在咱们个别开发中,对于工夫后端个别只会返回一个工夫戳让前端本人解决,上面比方定义一个转换工夫戳为日期格局的过滤器(留神步骤):
<template>
  <div>
    <!-- 4. 渲染数据,设置过滤器 -->
    {{times | conversion}}
  </div>
</template>
<script>
export default {data() {
    return {
      // 1. 模仿一个工夫戳数据
      times: 1616959086000,
    };
  },
  // 2. 定义过滤器
  filters: {
    //3. 定义一个处理函数,参数 value 为要解决数据
    conversion: function (value) {
      // 调用 Date 的办法,解决工夫戳
      return new Date(value).toLocaleString();},
  },
};
</script>

后果,转换胜利:

  1. 不仅如此,过滤器还能够串联,就是说能够定义多个过滤器,比方上面,相当于先用 conversion 函数解决 times 这个数据得出后果,而后持续用 againChange 函数解决后面的后果得出最终后果:

{{times | conversion | againChange}}
根本演示如下:

<template>
  <div>
    <!-- 5. 放过滤器 -->
    {{times | conversion | againChange}}
  </div>
</template>

<script>
export default {data() {
    return {
      // 1. 模仿一个工夫戳数据
      times: 1616959086000,
    };
  },
  // 2. 定义过滤器
  filters: {
    //3. 定义一个处理函数,参数 value 为要解决数据
    conversion: function (value) {
      // 调用 Date 的办法,解决工夫戳
      return new Date(value).toLocaleString();},
    //4. 再定义一个过滤器,给数据前加上 "工夫为:" 这几个字
    againChange: function (value) {return "工夫为:" + value;},
  },

};
</script>

  1. 同时,过滤器也是能够接管参数的,比方咱们改良第 1 小点的例子,把工夫戳转换为能指定格局的工夫格局,将想要的工夫格局作为过滤器参数,具体用法如下(留神步骤):
<template>
  <div>
    <!-- 4. 放过滤器, 同时传参数,返回指定格局的工夫 -->
    {{times | conversion("yyyy-MM-dd HH:mm:ss 星期 w") }}
  </div>
</template>

<script>
export default {data() {
    return {
      // 1. 模仿一个工夫戳数据
      times: 1616959086000,
    };
  },
  // 2. 定义过滤器
  filters: {
    //3. 定义一个处理函数,参数 value 为要解决数据,format 为传入参数
    conversion: function (value, format) {
      // 这个转换方法就不介绍了,看看就行,过滤器用法为主
      var date = new Date(value);
      function addZero(date) {if (date < 10) {return "0" + date;}
        return date;
      }
      let getTime = {yyyy: date.getFullYear(),
        yy: date.getFullYear() % 100,
        MM: addZero(date.getMonth() + 1),
        M: date.getMonth() + 1,
        dd: addZero(date.getDate()),
        d: date.getDate(),
        HH: addZero(date.getHours()),
        H: date.getHours(),
        hh: addZero(date.getHours() % 12),
        h: date.getHours() % 12,
        mm: addZero(date.getMinutes()),
        m: date.getMinutes(),
        ss: addZero(date.getSeconds()),
        s: date.getSeconds(),
        w: (function () {let a = ["日", "一", "二", "三", "四", "五", "六"];
          return a[date.getDay()];
        })(),};
      for (let i in getTime) {format = format.replace(i, getTime[i]);
      }
      return format;
    },
  },

};
</script>

后果如下:

三. 全局过滤器:

既然叫全局,那天然是在创立 Vue 实例之前全局定义过滤器,配置好后全副组件间接用就行。个别在自定义的一个文件里专门定义。比方还是下面的解决工夫戳的过滤器,用法如下:

1. 在 src 目录下定义 filters 文件夹,同时在文件夹里定义一个 filters.js 文件:

2.filters.js 文件代码如下:

const conversion = function (value, format) {var date = new Date(value);
      function addZero(date) {if (date < 10) {return "0" + date;}
        return date;
      }
      let getTime = {yyyy: date.getFullYear(),
        yy: date.getFullYear() % 100,
        MM: addZero(date.getMonth() + 1),
        M: date.getMonth() + 1,
        dd: addZero(date.getDate()),
        d: date.getDate(),
        HH: addZero(date.getHours()),
        H: date.getHours(),
        hh: addZero(date.getHours() % 12),
        h: date.getHours() % 12,
        mm: addZero(date.getMinutes()),
        m: date.getMinutes(),
        ss: addZero(date.getSeconds()),
        s: date.getSeconds(),
        w: (function () {let a = ["日", "一", "二", "三", "四", "五", "六"];
          return a[date.getDay()];
        })(),};
      for (let i in getTime) {format = format.replace(i, getTime[i]);
      }
      return format;
    }
  export {conversion // 通过此处导出办法} 

3. 在 main.js 里引入全局过滤器:

设置全局过滤器格局就是 Vue.filter(‘过滤器名称’,对应处理函数);

import {conversion} from './filters/filters.js'
Vue.filter('conversion', conversion);

4. 在某个组件间接能够应用:

<template>
  <div>
    <!-- 2. 放过滤器, 同时传参,为指定格局工夫 -->
    {{times | conversion("yyyy-MM-dd HH:mm:ss 星期 w") }}
  </div>
</template>

<script>
export default {data() {
    return {
      // 1. 模仿一个工夫戳数据
      times: 1616959086000,
    };
  },
};
</script>

一样的后果:

四. 扩大:

能够发现,filters 过滤器在用法上与 computed 计算属性有点像,那它们区别是什么呢?

  1. filters 能够传参,然而不能够拜访 this。不具备缓存性能。同时 filters 能够串联。能够在部分和全局设置。filter 比较简单,只在显式调用时触发,个别利用在模板渲染上。
  2. computed 不能够传参,能够拜访 this,针对的是变量的操作。背地的解决逻辑比较复杂,具备缓存能力,在组件内普适性更强,因而实用于简单的数据转换、统计等场景。

五. 总结:

下面就是 filters 过滤器的大抵内容了。总的来说,filters 过滤器能够分为部分过滤器和全局过滤器。部分过滤器在组件外部无效,全局过滤器在每个组件都无效。其中,能够设置多个过滤器和传参数给过滤器。个别过滤器利用在一些简略的数据渲染上。

点击关注,第一工夫理解华为云陈腐技术~

退出移动版