vue中的封装常用工具类

作者:vue呀vue 时间:2024-05-09 15:19:38 

vue封装常用工具类

公司要新开一个项目,我来分享一下简单封装常用的工具类

首先在util目录下创建一个Common.js文件

vue中的封装常用工具类

然后开始封装

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

也可以全局引入,接下来我说说全局引入

vue中的封装常用工具类

在main.js中直接引入。

vue中的封装常用工具类

然后就这么用,没了。

vue封装全局工具类并使用

1.创建js工具类文件

vue中的封装常用工具类

export default {
   getModelShowPic: function (menyType) {
     //test
   }
}

2.在min.ts中引用

import Common from '@/utils/Common.js
Vue.prototype.utils=Common

注意,如果提示错误utils/Common.js&rsquo; implicitly has an &lsquo;any&rsquo; type.,在tsconfig.json中添加:

vue中的封装常用工具类

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
  • asp之家 网络编程 m.aspxhome.com