我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue如何引入全局过滤器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue如何引入全局过滤器

Vue引入全局过滤器

创建单独的文件

加上时间过滤函数

将formatDate 暴露export 出来

// 时间戳转时分秒
function getformatDate (date, fmt) {
  if (/(y+)/.test(fmt)) {
      fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
  }
  let o = {
      'M+': date.getMonth() + 1,
      'd+': date.getDate(),
      'h+': date.getHours(),
      'm+': date.getMinutes(),
      's+': date.getSeconds()
  };
  for (let k in o) {
      if (new RegExp(`(${k})`).test(fmt)) {
          let str = o[k] + '';
          fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str));
      }
  }
  return fmt;
};

function padLeftZero (str) {
  return ('00' + str).substr(str.length);
};

 // 时间过滤
 export function formatDate(time) {
  return getformatDate(new Date(time), "yyyy-MM-dd hh:mm");
}

在main.js中全局引入

import * as filters from './filters' // global filters

// register global utility filters.
Object.keys(filters).forEach(key => {
  Vue.filter(key, filters[key])
})

在组件中使用formatDate过滤时间戳

          <el-table :data="item.children" style="width: 100%">
            <el-table-column prop="title" label="标题"></el-table-column>
            <el-table-column prop="portName" label="上传单位"></el-table-column>
            <el-table-column prop="createdTime" label="上传时间">
              <template slot-scope="scope">{{scope.row.createdTime | formatDate}}</template>
            </el-table-column>
          </el-table>

页面显示

vue全局过滤器配置

有时一个过滤器需要在项目中多次使用,此时可以将该过滤器定义为全局过滤器,全局过滤器在main.js下配置。

以时间过滤器为例,当为局部过滤器写为:

filters: {
  timeForm(val) {
 
        if (typeof (value) == "undefined" || value === null) return "";
 
        let date = new Date(value);
        var y = date.getFullYear();
        var m = date.getMonth() + 1;
        var d = date.getDate();
        if (isNaN(y) && y != 0) {
          y = " ";
        }
        if (isNaN(m) && m != 0) {
          m = " ";
        } else {
          (m < 10 ? "0" + m : m);
        }
        if (isNaN(d) && d != 0) {
          d = " ";
        } else {
          (d < 10 ? "0" + d : d);
        }
 
        return y + "-" + m + "-" + d + " " + date.toTimeString().substr(0, 5);
}

现在我们把它设置成全局过滤器

Vue.filter('timeForm', function (value) {
  if (typeof (value) == "undefined" || value === null) return "";
 
  let date = new Date(value);
  var y = date.getFullYear();
  var m = date.getMonth() + 1;
  var d = date.getDate();
  if (isNaN(y) && y != 0) {
    y = " ";
  }
  if (isNaN(m) && m != 0) {
    m = " ";
  } else {
    (m < 10 ? "0" + m : m);
  }
  if (isNaN(d) && d != 0) {
    d = " ";
  } else {
    (d < 10 ? "0" + d : d);
  }
  return y + "-" + m + "-" + d + " " + date.toTimeString().substr(0, 5);
});
var timeForm = Vue.filter('timeForm');
  • 直接定义为:Vue.filter('timeForm', function (value) { //过滤代码}
  • 然后定义一下过滤器:var timeForm = Vue.filter('timeForm')   

使用的时候和局部过滤器相同方式使用,直接{{   value   |  filter   }}  即可

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue如何引入全局过滤器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue如何引入全局过滤器

这篇文章主要介绍了Vue如何引入全局过滤器问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

vue如何全局引入scss

小编给大家分享一下vue如何全局引入scss,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、mixin.scss// 颜色定义规范$color-backgrou
2023-06-25

vue全局过滤器怎么设置(教程)

Vue.js 全局过滤器教程Vue.js 是一个高效、灵活并且易于学习的前端框架,具有响应式和组件化的特性。Vue.js 还提供了一种很便捷的方式来处理数据,那就是 Vue.js 的过滤器。在 Vue.js 中,过滤器可以用于转换数据。通常我们要将数据进行格式化以满足应用程序的需求,比如日期格式化、货币格式化等。在 Vue.js 中,全局过滤器可以被注册,以便在应用程序的任何部
2023-05-14

vue全局过滤器基本使用方法是什么

本篇内容介绍了“vue全局过滤器基本使用方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一.过滤器的概念Vue.js允许你自定义过滤
2023-06-25

vue中过滤器如何使用

这篇文章主要介绍“vue中过滤器如何使用”,在日常操作中,相信很多人在vue中过滤器如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中过滤器如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-29

springcloud如何整合gateway实现网关全局过滤器功能

这篇文章主要讲解了“springcloud如何整合gateway实现网关全局过滤器功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springcloud如何整合gateway实现网关全局过
2023-06-29

Vue中如何使用filters过滤器

这篇文章主要为大家展示了“Vue中如何使用filters过滤器”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue中如何使用filters过滤器”这篇文章吧。Vue.js 允许我们自定义过滤器,
2023-06-29

vue如何定义私有过滤器

小编给大家分享一下vue如何定义私有过滤器,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!私有过滤器和全局过滤器的方法和概念都相同,只是一个是全局都可以调用,而私有的只有自己可以调用,全局过滤器点这里全局过滤器使用方法也和全
2023-06-25

VUE中的filters过滤器如何使用

这篇文章主要讲解了“VUE中的filters过滤器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VUE中的filters过滤器如何使用”吧!前言Vue.js 允许我们自定义过滤器,可
2023-06-29

vue如何实现全局接入百度地图

小编给大家分享一下vue如何实现全局接入百度地图,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、获取ak密钥1、登录网址 https://lbsyun.baidu.com/注册百度地图开放平台账号,填写认证信息,并且创建
2023-06-29

编程热搜

目录