vue中的封装常用工具类
作者:vue呀vue 时间:2024-05-09 15:19:38
vue封装常用工具类
公司要新开一个项目,我来分享一下简单封装常用的工具类
首先在util目录下创建一个Common.js文件
然后开始封装
1.验证手机号是否合格
true 合格
export function isPhone(phoneStr) {
let myreg = /^[1][3,4,5,7,8,9][0-9]{9}$/;
if (!myreg.test(phoneStr)) {
return false;
} else {
return true;
}
}
2.验证身份证号是否合格
true 说明合格
export function isIdCard(idCardStr) {
let idcardReg = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/;
if (idcardReg.test(idCardStr)) {
return true;
} else {
return false;
}
}
3.验证字符串是否为空
ture 说明为空 false 说明不为空
export function isEmptyString(string) {
if (
string == undefined ||
typeof string == 'undefined' ||
!string ||
string == null ||
string == '' ||
/^\s+$/gi.test(string)
) {
return true;
} else {
return false;
}
}
4.判断数据类型
* @param {any} val - 基本类型数据或者引用类型数据
* @return {string} - 可能返回的结果有,均为小写字符串
* number、boolean、string、null、undefined、array、object、function等
*/
export function getType(val) {
//判断数据是 null 和 undefined 的情况
if (val == null) {
return val + "";
}
return typeof (val) === "object" ?
Object.prototype.toString.call(val).slice(8, -1).toLowerCase() :
typeof (val);
}
5.验证是否为数字
export function isNumber(n) {
return !isNaN(parseFloat(n)) && isFinite(n);
}
6.是否为数组
export function isArray(obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
}
7.是否为空数组
export function isArrayEmpty(val) {
if (val && val instanceof Array && val.length > 0) {
return false;
} else {
return true;
}
}
8.获取url参数字符串
没有返回null
export function getQueryString(name) {
let reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
let r = window.location.search.substr(1).match(reg);
if (r != null) {
return unescape(r[2]);
}
return null;
}
9.函数防抖
/**
* @desc 函数防抖,用于将多次执行变为最后一次执行
* @param {function} func - 需要使用函数防抖的被执行的函数。必传
* @param {Number} wait - 多少毫秒之内触发,只执行第一次,默认1000ms。可以不传
*/
export function debounce(fn, delay) {
delay = delay || 1000; //默认1s后执行
let timer = null;
return function () {
let context = this;
let arg = arguments;
if (timer) {
clearTimeout(timer);
}
timer = setTimeout(() => {
fn.apply(context, arg);
}, delay);
};
}
10.函数节流
/**
* 节流函数, 用于将多次执行变为每隔一段时间执行
* @param fn 事件触发的操作
* @param delay 间隔多少毫秒需要触发一次事件
*/
export function throttle2(fn, delay) {
let timer = null;
return function () {
let context = this;
let args = arguments;
if (!timer) {
timer = setTimeout(function () {
fn.apply(context, args);
clearTimeout(timer);
}, delay);
}
};
}
11.将字符串时间转换为时间戳
/**
* 将字符串时间转换为时间戳
* @param {string} date
*/
export function getDateTime(date) {
let timestamp = '';
if (date) {
date = date.substring(0, 19);
date = date.replace(/-/g, '/'); //必须把日期'-'转为'/'
timestamp = new Date(date).getTime();
}
return timestamp;
}
12.获取年-月-日
/**
* 获取年-月-日
* @data {Any} 时间戳
*/
export function getDates(data) {
let timeObj = {};
data = new Date(data);
let y = data.getFullYear();
let m =
data.getMonth() + 1 < 10
? '0' + (data.getMonth() + 1)
: data.getMonth() + 1;
let d = data.getDate() < 10 ? '0' + data.getDate() : data.getDate();
let w = data.getDay();
switch (w) {
case 1:
w = '星期一';
break;
case 2:
w = '星期二';
break;
case 3:
w = '星期三';
break;
case 4:
w = '星期四';
break;
case 5:
w = '星期五';
break;
case 6:
w = '星期六';
break;
case 7:
w = '星期日';
break;
}
let h = data.getHours() < 10 ? '0' + data.getHours() : data.getHours();
let mi = data.getMinutes() < 10 ? '0' + data.getMinutes() : data.getMinutes();
let s = data.getSeconds() < 10 ? '0' + data.getSeconds() : data.getSeconds();
timeObj = {
year: y + '',
month: m + '',
day: d + '',
week: w + '',
hour: h + '',
minute: mi + '',
second: s + ''
};
return timeObj;
}
然后就是引入问题,如果你不嫌麻烦,你就哪里用到了,你那里引入这个js
也可以全局引入,接下来我说说全局引入
在main.js中直接引入。
然后就这么用,没了。
vue封装全局工具类并使用
1.创建js工具类文件
export default {
getModelShowPic: function (menyType) {
//test
}
}
2.在min.ts中引用
import Common from '@/utils/Common.js
Vue.prototype.utils=Common
注意,如果提示错误utils/Common.js’ implicitly has an ‘any’ type.,在tsconfig.json中添加:
3.使用
this.utils.getModelShowPic(modelType);
来源:https://blog.csdn.net/weixin_45680713/article/details/118787935
标签:vue,封装,工具类
0
投稿
猜你喜欢
比较SQL Server约束和DML触发器
2008-12-24 15:54:00
python 在某.py文件中调用其他.py内的函数的方法
2021-02-25 23:56:09
MySQL系列之十一 日志记录
2024-01-13 16:20:38
Python中转换角度为弧度的radians()方法
2021-08-11 16:21:59
关于JDBC与MySQL临时表空间的深入解析
2024-01-22 04:11:14
利用Python写一个爬妹子的爬虫
2021-07-22 12:44:51
优雅使用GoFrame共享变量Context示例详解
2024-04-27 15:27:02
用unescape反编码得出汉字示例
2024-04-19 09:48:52
MYSQL数据库设计的一点总结
2008-05-24 09:36:00
CSS盒模型
2009-06-09 14:23:00
教会你完全搞定MySQL数据库 轻松八句话
2024-01-26 22:34:53
防止别人iframe的js
2008-09-26 17:19:00
Python tkinter进度条控件(Progressbar)的使用
2023-08-01 20:24:21
Python全栈之文件函数和函数参数
2023-05-11 02:28:21
详解Python的Django框架中的Cookie相关处理
2022-07-05 00:13:53
PHP遍历目录函数opendir()、readdir()、closedir()、rewinddir()总结
2024-05-03 15:53:21
Python 实现两个服务器之间文件的上传方法
2022-04-22 10:32:03
php源码的使用方法讲解
2023-06-17 21:47:02
Scratch3.0二次开发之windows环境下打包成exe的流程
2022-12-31 03:27:34
golang goquery selector选择器使用示例大全
2023-10-14 15:40:58