在vue中使用过滤器对日期进行格式化,解决vue 动态拼接地址,使用本地的图片不显示

1.新建date.js文件

// 对Date的扩展,将 Date 转化为指定格式的String
// 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,
// 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
// (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
// (new Date()).Format("yyyy-M-d h:m:s.S")      ==> 2006-7-2 8:9:4.18
Date.prototype.Format = function (fmt) {
    var o = {
        "M+": this.getMonth() + 1,                 //月份
        "d+": this.getDate(),                    //日
        "h+": this.getHours(),                   //小时
        "m+": this.getMinutes(),                 //分
        "s+": this.getSeconds(),                 //秒
        "q+": Math.floor((this.getMonth() + 3) / 3), //季度
        "S": this.getMilliseconds()             //毫秒
    };
    if (/(y+)/.test(fmt))
        fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
    for (var k in o)
        if (new RegExp("(" + k + ")").test(fmt))
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
    return fmt;
}   

export function formatTimeToStr(times, pattern) {
    var d = new Date(times).Format("yyyy-MM-dd hh:mm:ss");
    if (pattern) {
        d = new Date(times).Format(pattern);
    }
    return d.toLocaleString();
}

2.在vue中对日期格式化,使用过滤器方式

<template>
  <div>
  <span>{{date | formatDate}}</span>
  </div>
  </template>
import {formatTimeToStr} from './js/date.js';
  export default {
    date() {
        return {
            date: 1496311370052
        }
    },
  filters: {
   formatDate: function(time) {
        if(time!=null&&time!="")
        {
          var date = new Date(time);
          return formatTimeToStr(date, "yyyy-MM-dd");
        }else{
          return "";
        }
      }
  }

3、在方法中对时间格式化

<template>
  <div>
    <ul>
     <li v-for="item in arr">
       <input type="text" v-model="item.createTime" />
     </li>
    </ul>
  </div>
  </template>
import {formatTimeToStr} from './js/date.js';
  export default {
    date() {
        return {
            date: 1496311370052
        }
    },
   mounted:{
    this. axios.get('/user', {
          params: {
            ID: 12345
          }
        })
    .then(function (res) {
        this.arr = res.body;
            for(var i=0; i<this.arr.length; i++){
              this.arr[i].createTime = formatTimeToStr(this.arr[i].createTime, 'yyyy-MM-dd')
            }
        })
       }
 }

vue 动态拼接地址,使用本地的图片不显示

<el-col :span="4" v-for="(item, index) in listData" :key="index">
        <div class="grid-content grid-icon">
          <router-link :to="item.url.replace('/', '-')">
            <!--<img src="'../../assets/img/'+item.imgUrl)" alt="">-->   //动态拼接地址,使用本地的图片不显示
            <img :src="require('../../assets/img/'+item.imgUrl)" alt=""> //换这个方法
            <span>{{item.name}}</span>
            <span>{{item.enName}}</span>
          </router-link>
        </div>
      </el-col>

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值