今天写页面时遇到时间格式处理问题,想起前几天在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
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24//格式化时间 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; }
在组件里
复制代码
1
2import crtTimeFtt from '../../assets/js/common';
然后直接使用就好了
最后
以上就是奋斗寒风最近收集整理的关于vue引用其他组件的method的全部内容,更多相关vue引用其他组件内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复