有时候,我们需要对js的原生对象进行扩展,达到全局使用更方便的效果。而这种扩展往往并非vue模块化的js格式。下面讲解vue项目中如何导入非模块化js
/****
* 扩展日期格式化
* 使用参考:
* var time1 = new Date().Format("yyyy-MM-dd");
* var time2 = new Date().Format("yyyy-MM-dd hh:mm:ss");
* @param fmt
* @returns {*}
* @constructor
*/
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;
}
在main.js文件中导入
import "@/utils/expandJs"
在public的index.html中导入。
在public目录下创建一个js目录并将扩展js放在里面,然后index.html通过<script>标签引入
index.html引入参考
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title><%= webpackConfig.name %></title>
</head>
<body>
<noscript>
<strong>We're sorry but <%= webpackConfig.name %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
<script type="text/javascript" src="<%= BASE_URL %>js/extends.js"></script>
<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.15&key=3f5dc6c9fe58fdeef1729a040f5da333"></script>
</body>
</html>
https://www.leftso.com/article/916.html