vue引用其他组件的method

今天写页面时遇到时间格式处理问题,想起前几天在messageHistory.vue的methods里写过,就想引入messageHistory.vue的crtTimeFtt方法,
开始用import crtTimeFtt from '../notifyCenter/messageHistory',然后在下面直接调用,报错,说crtTimeFtt没有export,这里真是迷了,在messageHistory.vue根本没有导出crtTimeFtt,后来导入import messageHistory from '../notifyCenter/messageHistory,再使用crtTimeFtt,报错,crtTimeFtt没有定义,
尝试使用messageHistory.methods.crtTimeFtt,发现可以使用,这是一种方法。

如果在本页面中使用到了某个组件,给组件加ref属性,也可以通过下面的方法调用。
this.$refs['basetable'].query(this.query);(这里query是子组件的方法)

也可以把crtTimeFtt写在js文件里,export导出,在需要使用的组件里,直接导入就好了,觉得这种还是比较好的。具体如下

common.js

//格式化时间
export default function crtTimeFtt(value) {
  var crtTime = new Date(value);
  return dateFtt("yyyy-MM-dd hh:mm:ss", crtTime);//直接调用公共JS里面的时间类处理的办法
}

function dateFtt(fmt, date) {
  var o = {
    "M+": date.getMonth() + 1,                 //月份
    "d+": date.getDate(),                    //日
    "h+": date.getHours(),                   //小时
    "m+": date.getMinutes(),                 //分
    "s+": date.getSeconds(),                 //秒
    "q+": Math.floor((date.getMonth() + 3) / 3), //季度
    "S": date.getMilliseconds()             //毫秒
  };
  if (/(y+)/.test(fmt))//这里就是找到第一个y集合,代替
    fmt = fmt.replace(RegExp.$1, (date.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;
}

在组件里

import crtTimeFtt from '../../assets/js/common';

然后直接使用就好了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值