整理工作中的常用到的工具类

为了提高开发效率,所以就想整理一下比较常用的工具类。其中有些是自己写的,有些是别人造的轮子,有些具体的作者是谁不太清楚,我就没注明。如果有侵权或什么的请告知!谢谢。

 /**
   value:需要格式化的值
   currency : 货币符号,默认值为$
   decimals : 精度,默认保留2位
 */
const digitsRE = /(\d{3})(?=\d)/g

export function currency (value, currency, decimals) {
  value = parseFloat(value)
  if (!isFinite(value) || (!value && value !== 0)) return ''
  currency = currency != null ? currency : '$'
  decimals = decimals != null ? decimals : 2
  var stringified = Math.abs(value).toFixed(decimals)
  var _int = decimals
    ? stringified.slice(0, -1 - decimals)
    : stringified
  var i = _int.length % 3
  var head = i > 0
    ? (_int.slice(0, i) + (_int.length > 3 ? ',' : ''))
    : ''
  var _float = decimals
    ? stringified.slice(-1 - decimals)
    : ''
  var sign = value < 0 ? '-' : ''
  return sign + currency + head +
    _int.slice(i).replace(digitsRE, '$1,') +
    _float
}
  • 解析url
/**
 * 解析url参数
 * @example ?id=12345&a=b
 * @return Object {id:12345,a:b}
 */
export function urlParse() {
  let url = window.location.search;
  let obj = {};
  let reg = /[?&][^?&]+=[^?&]+/g;
  let arr = url.match(reg);
  // ['?id=12345', '&a=b']
  if (arr) {
    arr.forEach((item) => {
      let tempArr = item.substring(1).split('=');
      let key = decodeURIComponent(tempArr[0]);
      let val = decodeURIComponent(tempArr[1]);
      obj[key] = val;
    });
  }
  return obj;
};
function getRandomColor() {
  let rgb = []
  for (let i = 0; i < 3; ++i) {
    let color = Math.floor(Math.random() * 256).toString(16)
    color = color.length == 1 ? '0' + color : color
    rgb.push(color)
  }
  return '#' + rgb.join('')
}

结果如下:
生成随机16进制颜色值

  • 判断客户端类型
//判断是否是微信内置浏览器
function Is_Weixin() {

            var ua = window.navigator.userAgent.toLowerCase();

            if (ua.match(/MicroMessenger/i) == 'micromessenger') {

                return true;

            } else {

                return false;

            }

        }
//判断是否是pc端
        function Is_PC() {

            var userAgentInfo = navigator.userAgent;

            var Agents = ["Android", "iPhone",

                "SymbianOS", "Windows Phone",

                "iPad", "iPod"
            ];

            var flag = true;

            for (var v = 0; v < Agents.length; v++) {

                if (userAgentInfo.indexOf(Agents[v]) > 0) {

                    flag = false;

                    break;

                }

            }

            return flag;

        }


//判断是Ios 还是 Android
        function Is_PhoneType() {

            var u = navigator.userAgent,
                app = navigator.appVersion;

            var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1; //g

            var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端

            if (isAndroid) {

                return "Android";

            }

            if (isIOS) {

                return "IOS";

            }

        }
  • 深度克隆
function deepClone(srcObj, out) {
  let outObj = out || {}
  for(let key in srcObj) {
    if(typeof srcObj[key] === 'object') {
      outObj[key] = (srcObj[key].constructor === Array) ? [] : {}
      deepClone(srcObj[key], outObj[key])
    } else {
      outObj[key] = srcObj[key]
    }
  }
  return outObj
}

未完待续,有好的可以在下方给我留言.….

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值