常用,好用的js代码
记录看到或者用到的js代码,长期更新!
判断是否是正整数
number>>>0 === number-0
解析: number-0 转换成数字,再通过位移运算(>>>)判断是否跟原数字相等
补充,这个代码是有范围的,当数字> 999999999 的时候就不成立了
原理可以参考这篇文章, 传送门
安全检查javascript的类型
function typeOf(o){
let _toString = Object.prototype.toString;
//列举基本的数据类型和内置的对象类型
let _types = {
"undefined" : "undefined",
"number" : "number",
"string" : "string",
"boolean" : "boolean",
"[object Function]" : "function",
"[object Array]" : "array",
"[object Date]" : "date",
"[object RegExp]" : "regExp",
"[object Error]" : "error"
}
return _types[typeof o] || _types[_toString.call(o)] || (o? "object":"null");
}
ps: 上述方法适用于基本的数据类型和内置对象,而对于自定义对象是无效的。
判断是不是数组
function isArray(arr){
return Object.prototype.toString.call(arr) === '[object Array]'
}
判断是不是ios系统
function isIOS(){
let u = navigator.userAgent;
let isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端
return isIOS;
}
转成字符串
function toString (val) {
return val == null
? ''
: typeof val === 'object'
? JSON.stringify(val, null, 2)
: String(val)
}
中划线转驼峰
function camelize(str){
var reg = /([a-z]?)-([a-z])/g;
var index = 0;
return str.replace(reg,function(r,$1,$2){
if($1){
return $2?$1+$2.toUpperCase():'';
}else{
return $2;
}
})
}
驼峰转中划线
function camelize(str){
return str.replace(/\B([A-Z])/g, '-$1').toLowerCase();
}
首字母大写
function capitalize(str){
return str.charAt(0).toUpperCase() + str.slice(1);
}
获取url的query,返回指定key的值
function getUrlParam(sUrl, sKey) {
var index = sUrl.indexOf('?');
var urlStr = sUrl.substr(index+1);
var reg = /&?([^=]+)=([^&#]+)/g;
var result = {};
urlStr.replace(reg,function(re,$1,$2){
if(result[$1]){
var item = result[$1];
result[$1] = [].concat(item,$2);
}else{
result[$1] = $2;
}
});
if(sKey){
return result[sKey]||'';
}else{
return false
}
}
快速对数据进行降维打击(多维->一维)
var arr = [[1],[2]];
var arr2 = Array.prototype.concat.apply([],arr); //划重点 ,这个只能是二维->一维
var arr3 = arr.flat(Infinity); //多维->一维
h5页面跳转小程序
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=="micromessenger"){
wx.miniProgram.getEnv((res)=>{
if (res.miniprogram) {
// 如果在小程序环境中就跳转
wx.miniProgram.redirectTo({
url: '.......'
});
return;
}
})
}
判断是不是promise对象
function isPromise(val){
return (
val!==undefined&&
val!== null &&
typeof val.then === 'function' &&
typeof val.catch === 'function'
)
}
软绑定
不同于硬绑定,软绑定可以给默认绑定指定一个全局对象和undefined以外的值,那就可以实现和硬绑定相同的效果,同时保留隐式绑定或者显式绑定修改this的能力!
if(! Function.prototype.softBind){
Function.prototype.softBind = function(obj){
var fn = this;
var curried = [].slice.call(arguments,1);
var bound = function(){
return fn.apply(
(!this || this === (window || global)) ?
obj : this,
curried.concat.apply(curried,arguments)
);
};
bound.prototype = Object.create(fn.prototype);
return bound;
}
}
判断一个字符串一定可以转成数字
function isNumberic(n){
return !Number.isNaN(parseFloat(n)) && Number.isFinite(Number(n));
}
这代码比你想象中的要难理解许多
JSON序列化Error对象
如果对error对象直接用JSON.stringify(),直接打印"{}"; 那是因为error对象的属性是不可遍历的;可以用Object.getOwnPropertyNames()获取自身的属性
var error = new Error('this is a error message');
JSON.stringify(error,Object.getOwnPropertyNames(error));
格式化日期
输入一个date对象,并根据格式输出
function formatDate(date,format){
var o = {
'y+': date.getFullYear(),
'M+': date.getMonth()+1,
'd+': date.getDate(),
'H+': date.getHours(),
'h+': date.getHours()> 12? date.getHours()-12: date.getHours(),
'm+': date.getMinutes(),
's+': date.getSeconds(),
'w': date.getDay()
};
var weekends = ['日', '一', '二', '三', '四', '五', '六'];
for(var k in o){
if(new RegExp('('+k+')').test(format)){
if(k=='y+'){
format = format.replace(RegExp.$1, (o[k]+'').substr(4- RegExp.$1.length));
}else if(k=='w'){
format = format.replace(RegExp.$1,weekends[o[k]]);
}else{
format = format.replace(RegExp.$1, RegExp.$1.length==1? o[k]: ('00'+o[k]).substr((''+o[k]).length))
}
}
}
return format;
}
获取字符的真实长度
一般中文字符都是两个字节的
function getLength(s){
var len = s.length;
var reg = /[\u4e00-\u9fa5]/;
for(var i=0;i<len;i++){
if(reg.test(s.charAt(i))){
len+=2;
}else{
len+=1;
}
}
return len;
}
rgb 颜色字符串转换为十六进制
比如把
rgb(255,255,255)
转成#ffffff
。 关键在于,可以用.toString(16)
方法把数字转成十六进制
function reg2hex(sRGB){
var reg = /rgb\((\d+),\s*(\d+),\s*(\d+)\)/;
var rs = sRGB.match(reg);
if(!rs){
return sRGB;
}else{
var str = '#';
for(var i=1;i<=3;i++){
var n = parseInt(rs[i]);
if(n<0 || n>255){return sRGB}
str += n>16? n.toString(16): '0'+n.toString(16);
}
return str;
}
}
十进制和二进制的转换
// 十进制转二进制
num.toString(2);
// 二进制转十进制
parseInt(num,2);
获取全局变量global(在不同的环境)
// self 是window的保留关键字, 在浏览器中指向window对象
var global = typeof window != 'undefined' && window.Math == Math
? window : typeof self != 'undefined' && self.Math == Math ? self : Function('return this')();
常用,好用的js代码的更多相关文章
- 站长常用的200个js代码 站长常用js代码大全 站长常用js代码集合
站长常用的200个js代码 1.文本框焦点问题 onBlur:当失去输入焦点后产生该事件 onFocus:当输入获得焦点后,产生该文件 Onchange:当文字值改变时,产生该事件 Onselect: ...
- 常用近百个js代码汇总
//檢查空串 function isEmpty(str){ )) return (true); else return(false); } //檢查是否未數字 function isDigit(the ...
- 常用js代码整理、收集
个人整理了一下个人常用到的一些js代码,以方便学习以及日后使用,或许有一些是个人之前从网上摘下来的,但是不记得是具体从哪里来的了,如果你看到有一段代码跟你的文章很相似甚至一样,请不要气愤,请告诉我,我 ...
- 可重复使用Tab切换代码和纯js代码
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- js 常用正则表达式表单验证代码
正则表达式使用详解 简介 简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具.其作用如下:测试字符串的某个模式.例如,可以对一个输入字符串进行测试,看在该字符串是否存在一个电话号码模式或一 ...
- js常用正则表达式表单验证代码
方法一: var re=/正则表达式/; re.test($("txtid").val()) 方法二: $("txtid").val.match(/正则 ...
- Google Chrome调试js代码,开发者工具之调试工具常用功能
参考:Google Chrome调试js代码-http://www.open-open.com/lib/view/open1384785324165.html 重点:左下角一个{}括号图标按钮用于把杂 ...
- selenium常用操作,查找元素,操作Cookie,获取截图,获取窗口信息,切换,执行js代码
目录: 1. 常用操作 2. 查找元素 3. 操作Cookie 4. 获取截图 5. 获取窗口信息 6. 切换 7. 执行JS代码 简介 selenium.webdriver.remote.webdr ...
- 127个常用的JS代码片段,每段代码花30秒就能看懂(上)
127个常用的JS代码片段,每段代码花30秒就能看懂(上) JavaScript 是目前最流行的编程语言之一,正如大多数人所说:“如果你想学一门编程语言,请学JavaScript.” FreeCode ...
随机推荐
- 一步步Cobol 400上手自学入门教程05 - 表
在COBOL中有几类典型结构的表.这几类典型结构的表在大体上可分为下标表和索引表两大类.另外,根据表的重复次数定义又有定长表和变长表.此外,表还允许嵌套,因此还有嵌套表.这几类表均符合表的基本定义,都 ...
- django -- 美多订单分表
订单分表: 随着公司业务增长,如果每天1000多万笔订单的话,3个月将有约10亿的订单量,之前数据库采用单表的形式已经不满足于业务需求,数据库改造迫在眉睫. 解决思路: 按月分表,将原订单表拆分为 o ...
- Python程序的打包-上传到pypi
pypi注册与配置 在pypi的官网:https://pypi.python.org/pypi 注册自己的账号激活账号之后,我们还需要将在本地配置一份文件 在用户的根目录创建文件 : .pypirc在 ...
- Pycharm配置autopep8:自动调整代码为PEP8风格
关于PEP 8 PEP 8,Style Guide for Python Code,是Python官方推出编码约定,主要是为了保证 Python 编码的风格一致,提高代码的可读性. 官网地址:http ...
- 提取PPT中的原始图片
写Word的不如做Excel 的,做Excel不如做PPT的,写代码的不如做PPT. 为了在电子邮件中上传PPT,其中的图片大都经过压缩,以便缩小PPT的体积.那么如何将PPT中的图片,还原成没有经过 ...
- Windows上安装tensorflow 详细教程
原博客转载自:https://www.cnblogs.com/lvsling/p/8672404.html 一, 前言:本次安装tensorflow是基于Python的,安装Python的过程不做说明 ...
- 10-02 Java 形式参数和返回值的问题深入研究,链式编程
形式参数和返回值的问题: 1:形式参数和返回值的问题(理解) (1)形式参数: 类名:需要该类的对象 抽象类名:需要该类的子类对象 接口名:需要该接口的实现类对象 (2)返回值类型: 类名:返回的是该 ...
- C#:使用HtmlAgilityPack解析Html
推荐阅读: HtmlAgilityPack 入门教程1 HtmlAgilityPack入门教程2 向HtmlAgilityPack道歉:解析HTML还是你好用 获取html中meta标签中的conte ...
- Java语法糖之内部类
例1: class Outer { public void md1(final int a) { final int b = 1; class LocalA { int c = a; } class ...
- postgresql 导出和导入数据库
使用 pg_dump 和 pg_restore 来备份和还原 postgresql的数据: 导出:pg_dump导入:pg_restore 最简单的导出命令如下:(导出指定数据库) $ pg_dump ...