js如何提高for循环的效率_让你瞬间提高工作效率的常用js函数汇总
前言
本文总结了项目开发过程中常用的js函数和正则,意在提高大家平时的开发效率,具体内容如下:
- 常用的正则校验
- 常用的设备检测方式
- 常用的日期时间函数
- 跨端事件处理
- js移动端适配方案
- xss预防方式
- 常用的js算法(防抖,截流,去重,排序,模板渲染,观察者...)
代码
- 正则
// 匹配邮箱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 = /^[一-龥]*$/;
- 检测平台(设备)类型
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);
- 常用的日期时间函数
// 时间格式化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 "时间到!";}
- 跨端事件处理
// 是否支持触摸事件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; } } }};
- 移动端适配方案
(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函数汇总相关推荐
- android效率工具,工具|5款瞬间提升工作效率的APP
原标题:工具|5款瞬间提升工作效率的APP 好签(iOS / Android) 好签是一款非常实用的手机办公软件,用户可以通过它随时签单,支持超多主流格式文档,线上签单更加方便.使用简单,签字顺滑,更 ...
- js中text方法是啥意识_一盏茶的时间,快速捕获JS中常用的方法(细心整理,持续更新ing)...
不知不觉上班一周辽-趁着大好周末,小编挣扎着从床上爬起来,决定对前端日常编程中常用到的一些方法做一个系统的整合. 有些人或许会觉得忘了百度就完事儿,no no no!这事儿小编真的亲践过好多次,百度一 ...
- mysql 分区 效率_【MySQL】MySQL分区表效率测试对比
这一段时间对数据库优化方面的认识深有体会,就以MySQL为例测试一下分区表的性能 MySQL5.0好像不支持分区,我用的5.5版本,测试是否支持可通过以下方法: SHOW VARIABLES LIKE ...
- java程序效率_优化JAVA程序的执行效率和性能
StringBuffer或者StringBuilder(线程不安全)来拼接或者操作 字符串就比直接使用String效率高. 避免在循环条件中使用复杂表达式 在不做编译优化的情况下,在循环中,循环条件会 ...
- 如何提高lstm的预测精度_直线电机点胶机如何提高点胶精度及生产效率?
直线电机点胶机如何提高点胶精度及生产效率? 传统的点胶机多数采用丝杆进行移动,通过电机带动丝杆转动,再进一步驱使点胶机的点胶机构移动到所需位置,这样的传动方式是利用了丝杆上的螺纹和点胶机构对应的螺纹连 ...
- excel函数大全_让你的EXCEL工作效率翻倍的函数大全
详细的函数说明和应用实例可查看我上传的<EXCEL快速学习教程视频>对应各类函数教程 常用函数大全 使用函数:公式选项卡>函数库>插入函数.常用函数.最近使用函数.财务.逻辑. ...
- parasolid 原因 效率_打赢了一场效率仗
近段时间实在是比较忙.最开心的事莫过于期待以久的房子终于确定下来了,估计月底左右可以拿到钥匙,这阵子每逢俺那口子休息,总是要一起去看装潢材料什么的,用来构思论文和从事开发的时间明显地没有以前多了. 半 ...
- mysql 递归查询 效率_性能优化实战-sql递归查询效率低下
今天在做一个热门赛事列表查询的接口压测 http://192.168.10.98:8094/match/page?matchType=0&matchTime=0&matchStatus ...
- excel中最常用的30个函数_最常用日期函数汇总excel函数大全收藏篇
在我们的实际工作中,经常需要用到日期函数.日期函数那么多,你还只会用函数TODAY吗?那你就OUT了.今天一起来看下常用日期函数的用法! 1.DATE 函数DATE:返回在日期时间代码中代表日期的数字 ...
最新文章
- 解决AttributeError: XXX instance has no attribute ‘xxx‘的问题(新手必备)
- Python代码注释
- windows 同时安装 python2 python3
- vsftp配置日志及其启用本地时间
- JS存取Cookies值
- python高效处理文件_使用Python语言高效地处理一个文本文件
- 微信公众帐号开发教程第13篇-图文消息全攻略
- glog 编译报错 ERROR macro is defined. Define GLOG_NO_ABBREVIATED_SEVERITIES before including logging.h.
- [面试] C/C++ 语法(七)—— C++ 类型转换
- RHCS集群 切换时defunct僵尸进程解决方案
- 算数平均数与几何平均数
- 经典美文诵读2 If I Were a Boy Again假如我又回到了童年
- .net学习笔记——学生信息管理系统(一、在SQL server中新建学生信息库)
- 华为服务器显示100错误,华为12708风扇狂转100%故障排除
- Android核心功能
- 布局Mac,QQ浏览器全面出击
- 项目实战No2 登陆注册
- k8s clientset 出现 Throttling request took 限流的解决方法
- NLP——4.朴素贝叶斯
- Java基础函数三要素