前言

本文总结了项目开发过程中常用的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 = /^[一-龥]*$/;
  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 + 

js如何提高for循环的效率_让你瞬间提高工作效率的常用js函数汇总相关推荐

  1. android效率工具,工具|5款瞬间提升工作效率的APP

    原标题:工具|5款瞬间提升工作效率的APP 好签(iOS / Android) 好签是一款非常实用的手机办公软件,用户可以通过它随时签单,支持超多主流格式文档,线上签单更加方便.使用简单,签字顺滑,更 ...

  2. js中text方法是啥意识_一盏茶的时间,快速捕获JS中常用的方法(细心整理,持续更新ing)...

    不知不觉上班一周辽-趁着大好周末,小编挣扎着从床上爬起来,决定对前端日常编程中常用到的一些方法做一个系统的整合. 有些人或许会觉得忘了百度就完事儿,no no no!这事儿小编真的亲践过好多次,百度一 ...

  3. mysql 分区 效率_【MySQL】MySQL分区表效率测试对比

    这一段时间对数据库优化方面的认识深有体会,就以MySQL为例测试一下分区表的性能 MySQL5.0好像不支持分区,我用的5.5版本,测试是否支持可通过以下方法: SHOW VARIABLES LIKE ...

  4. java程序效率_优化JAVA程序的执行效率和性能

    StringBuffer或者StringBuilder(线程不安全)来拼接或者操作 字符串就比直接使用String效率高. 避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会 ...

  5. 如何提高lstm的预测精度_直线电机点胶机如何提高点胶精度及生产效率?

    直线电机点胶机如何提高点胶精度及生产效率? 传统的点胶机多数采用丝杆进行移动,通过电机带动丝杆转动,再进一步驱使点胶机的点胶机构移动到所需位置,这样的传动方式是利用了丝杆上的螺纹和点胶机构对应的螺纹连 ...

  6. excel函数大全_让你的EXCEL工作效率翻倍的函数大全

    详细的函数说明和应用实例可查看我上传的<EXCEL快速学习教程视频>对应各类函数教程 常用函数大全 使用函数:公式选项卡>函数库>插入函数.常用函数.最近使用函数.财务.逻辑. ...

  7. parasolid 原因 效率_打赢了一场效率仗

    近段时间实在是比较忙.最开心的事莫过于期待以久的房子终于确定下来了,估计月底左右可以拿到钥匙,这阵子每逢俺那口子休息,总是要一起去看装潢材料什么的,用来构思论文和从事开发的时间明显地没有以前多了. 半 ...

  8. mysql 递归查询 效率_性能优化实战-sql递归查询效率低下

    今天在做一个热门赛事列表查询的接口压测 http://192.168.10.98:8094/match/page?matchType=0&matchTime=0&matchStatus ...

  9. excel中最常用的30个函数_最常用日期函数汇总excel函数大全收藏篇

    在我们的实际工作中,经常需要用到日期函数.日期函数那么多,你还只会用函数TODAY吗?那你就OUT了.今天一起来看下常用日期函数的用法! 1.DATE 函数DATE:返回在日期时间代码中代表日期的数字 ...

最新文章

  1. 解决AttributeError: XXX instance has no attribute ‘xxx‘的问题(新手必备)
  2. Python代码注释
  3. windows 同时安装 python2 python3
  4. vsftp配置日志及其启用本地时间
  5. JS存取Cookies值
  6. python高效处理文件_使用Python语言高效地处理一个文本文件
  7. 微信公众帐号开发教程第13篇-图文消息全攻略
  8. glog 编译报错 ERROR macro is defined. Define GLOG_NO_ABBREVIATED_SEVERITIES before including logging.h.
  9. [面试] C/C++ 语法(七)—— C++ 类型转换
  10. RHCS集群 切换时defunct僵尸进程解决方案
  11. 算数平均数与几何平均数
  12. 经典美文诵读2 If I Were a Boy Again假如我又回到了童年
  13. .net学习笔记——学生信息管理系统(一、在SQL server中新建学生信息库)
  14. 华为服务器显示100错误,华为12708风扇狂转100%故障排除
  15. Android核心功能
  16. 布局Mac,QQ浏览器全面出击
  17. 项目实战No2 登陆注册
  18. k8s clientset 出现 Throttling request took 限流的解决方法
  19. NLP——4.朴素贝叶斯
  20. Java基础函数三要素

热门文章

  1. token验证+vuex的localStorage应用
  2. Redis 发布订阅
  3. Spring AOP 的切点切在Controller上没有起作用的问题。
  4. Html5 web本地存储
  5. java中@value的环境配置
  6. Ubuntu+Win7+Samba实现文件共享
  7. Java 位运算和逻辑运算的区别
  8. Java静态变量的初始化
  9. why do we use process keys
  10. ECCV 2020 | 空间-角度信息交互的光场图像超分辨,性能优异代码已开源