前言

本文总结了项目开发过程中常用的js函数和正则,意在提高大家平时的开发效率,具体内容如下:

  1. 常用的正则校验

  2. 常用的设备检测方式

  3. 常用的日期时间函数

  4. 跨端事件处理

  5. js移动端适配方案

  6. xss预防方式

  7. 常用的js算法(防抖,截流,去重,排序,模板渲染,观察者...)

代码


  1. 正则

// 匹配邮箱let reg = /^([a-zA-Z]|[0-9])(\w|\-)+@[a-zA-Z0-9]+\.([a-zA-Z]{2,4})$// (新)匹配手机号let reg = /^1[0-9]{10}$/;// (旧)匹配手机号let reg = /^1[3|4|5|7|8][0-9]{9}$/;// 匹配8-16位数字和字母密码的正则表达式let reg = /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$/;// 匹配国内电话号码 0510-4305211let reg = /\d{3}-\d{8}|\d{4}-\d{7}/;// 匹配身份证号码let reg=/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/;// 匹配腾讯QQ号let reg = /[1-9][0-9]{4,}/;// 匹配ip地址let reg = /\d+\.\d+\.\d+\.\d+/;// 匹配中文let reg = /^[\u4e00-\u9fa5]*$/;复制代码


  1. 检测平台(设备)类型



let isWechat = /micromessenger/i.test(navigator.userAgent),    isWeibo = /weibo/i.test(navigator.userAgent),    isQQ = /qq\//i.test(navigator.userAgent),    isIOS = /(iphone|ipod|ipad|ios)/i.test(navigator.userAgent),    isAndroid = /android/i.test(navigator.userAgent);复制代码


  1. 常用的日期时间函数

// 时间格式化function format_date(timeStamp) {    let date = new Date(timeStamp);    return date.getFullYear() + "年"        + prefix_zero(date.getMonth() + 1) + "月"        + prefix_zero(date.getDate()) + "日 "        + prefix_zero(date.getHours()) + ":"        + prefix_zero(date.getMinutes());}// 数字格式化function prefix_zero(num) {    return num >= 10 ? num : "0" + num;}// 倒计时时间格式化function format_time(timeStamp) {    let day = Math.floor(timeStamp / (24 * 3600 * 1000));    let leave1 = timeStamp % (24 * 3600 * 1000);    let hours = Math.floor(leave1 / (3600 * 1000));    let leave2 = leave1 % (3600 * 1000);    let minutes = Math.floor(leave2 / (60 * 1000));    let leave3 = leave2 % (60 * 1000);    let seconds = Math.floor(leave3 / 1000);    if (day) return day + "天" + hours + "小时" + minutes + "分";    if (hours) return hours + "小时" + minutes + "分" + seconds + "秒";    if (minutes) return minutes + "分" + seconds + "秒";    if (seconds) return seconds + "秒";    return "时间到!";}复制代码


  1. 跨端事件处理

// 是否支持触摸事件let isSupportTouch = ("ontouchstart" in document.documentElement) ? true : false;//禁用Enter键表单自动提交document.onkeydown = function(event) {    let target, code, tag;    if (!event) {        event = window.event; //针对ie浏览器        target = event.srcElement;        code = event.keyCode;        if (code == 13) {            tag = target.tagName;            if (tag == "TEXTAREA") { return true; }            else { return false; }        }    }    else {        target = event.target; //针对遵循w3c标准的浏览器,如Firefox        code = event.keyCode;        if (code == 13) {            tag = target.tagName;            if (tag == "INPUT") { return false; }            else { return true; }        }    }};复制代码


  1. 移动端适配方案

(function (doc, win) {    var docEl = doc.documentElement,        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',        recalc = function () {            var clientWidth = docEl.clientWidth;            var fontSize = 20;            docEl.style.fontSize = fontSize + 'px';            var docStyles = getComputedStyle(docEl);            var realFontSize = parseFloat(docStyles.fontSize);            var scale = realFontSize / fontSize;            console.log("realFontSize: " + realFontSize + ", scale: " + scale);            fontSize = clientWidth / 667 * 20;            if(isIphoneX()) fontSize = 19;            fontSize = fontSize / scale;            docEl.style.fontSize = fontSize + 'px';        };    // Abort if browser does not support addEventListener    if (!doc.addEventListener) return;    win.addEventListener(resizeEvt, recalc, false);    doc.addEventListener('DOMContentLoaded', recalc, false);    // iphoneX判断    function isIphoneX(){        return /iphone/gi.test(navigator.userAgent) && (screen.height == 812 && screen.width == 375)    }})(document, window);复制代码


  1. xss预防方式

// 敏感符号转义function entities(s) {    let e = {        '"': '&quot;',        '&': '&amp;',        '<': '&lt;',        '>': '&gt;'    }    return s.replace(/["<>&]/g, m => {        return e[m]    })}复制代码


  1. 常用的js算法

/** * 节流函数--规定在一个单位时间内,只能触发一次函数。如果这个单位时间内触发多次函数,只有一次生效。 */function throttle(fun, delay) {    let last, deferTimer    return function (args) {        let that = this        let _args = arguments        let now = +new Date()        if (last && now < last + delay) {            clearTimeout(deferTimer)            deferTimer = setTimeout(function () {                last = now                fun.apply(that, _args)            }, delay)        }else {            last = now            fun.apply(that,_args)        }    }}/** * 防抖函数--在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时 */ function debounce(fun, delay) {    return function (args) {        let that = this        clearTimeout(fun.id)        fun.id = setTimeout(function () {            fun.call(that, args)        }, delay)    }}// 观察者模式let Observer = (function(){  let t __messages = {};  return {    regist: function(type, fn) {      if(typeof __messages[type] === 'undefined') {        messages[type] = [fn];      }else {        __messages[type].push(fn);      }    },    fire: function(type, args) {      if(!__messages[type]){        return      }      let events = {        type: type,        args: args || {}      },      i = 0,      len = __messages[type].length;      for(;i<len;i++){        __messages[type][i].call(this, events);      }    },    remove: function(type, fn) {      if(__messages[type] instanceof Array){        let i = __messages[type].length -1;        for(;i>=0;i--){          __messages[type][i] === fn && __messages[type].splice(i, 1)        }      }    }  }})(); // 模板渲染方法 function formatString(str, data) {   return str.replace(/\{\{(\w+)\}\}/g, function(match, key) {     return typeof data[key] === undefined ? '' : data[key]   }) }  // 冒泡排序function bubbleSort(arr) {    for (let i = arr.length - 1; i > 0; i--) {      for (let j = 0; j < i; j++) {        if (arr[j] > arr[j + 1]) {          swap(arr, j, j + 1);        }      }    }    return arr;}// 置换函数function swap(arr, indexA, indexB) {    [arr[indexA], arr[indexB]] = [arr[indexB], arr[indexA]];}// 数组去重function distinct(arr = testArr) {    return arr.filter((v, i, array) => array.indexOf(v) === i)}复制代码

后期会继续总结更多工作中遇到的经典函数,也作为自己在工作中的一点总结。我们当然也可以直接使用lodash或ramda这些比较流行的函数式工具库,在这里仅做学习参考使用。

附录 lodash API中文翻译思维导图




        公众号后台回复 lodash思维导图  获得高清源文件

欢迎关注下方公众号,让我们一起探讨前端的边界:


在公众号点击进群,可以加入vue学习小组,一起学习前端技术


更多推荐

  • 一张图教你快速玩转vue-cli3

  • 3分钟教你用原生js实现具有进度监听的文件上传预览组件

  • 3分钟教你用原生js实现具有进度监听的文件上传预览组件

  • 使用Angular8和百度地图api开发《旅游清单》

  • js基本搜索算法实现与170万条数据下的性能测试

  • 《前端算法系列》如何让前端代码速度提高60倍

  • 《前端算法系列》数组去重

  • 如何把控css的方向感

  • vue高级进阶系列——用typescript玩转vue和vuex

  • 前端三年,谈谈最值得读的5本书籍



趣谈前端

微信搜索:趣谈前端

关注


欢迎扫码关注    趣谈前端

解决 程序猿单身 问题