写点什么

带你掌握 Vue 过滤器 filters 及时间戳转换

发布于: 2 小时前

​​摘要: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>
复制代码


结果,转换成功:



2. 不仅如此,过滤器还可以串联,就是说可以定义多个过滤器,比如下面,相当于先用 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>
复制代码



3. 同时,过滤器也是可以接收参数的,比如我们改进第 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 过滤器可以分为局部过滤器和全局过滤器。局部过滤器在组件内部有效,全局过滤器在每个组件都有效。其中,可以设置多个过滤器和传参数给过滤器。一般过滤器应用在一些简单的数据渲染上。


点击关注,第一时间了解华为云新鲜技术~

发布于: 2 小时前阅读数: 3
用户头像

提供全面深入的云计算技术干货 2020.07.14 加入

华为云开发者社区,提供全面深入的云计算前景分析、丰富的技术干货、程序样例,分享华为云前沿资讯动态,方便开发者快速成长与发展,欢迎提问、互动,多方位了解云计算! 传送门:https://bbs.huaweicloud.com/

评论

发布
暂无评论
带你掌握Vue过滤器filters及时间戳转换