当前位置: 代码网 > it编程>前端脚本>Vue.js > Vue如何引入全局过滤器

Vue如何引入全局过滤器

2024年05月18日 Vue.js 我要评论
vue引入全局过滤器创建单独的文件加上时间过滤函数将formatdate 暴露export 出来// 时间戳转时分秒function getformatdate (date, fmt) { if (

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   }}  即可

总结

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

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com