分享12个非常实用的JavaScript小技巧


Posted in Javascript onMay 11, 2016

在这篇文章中将给大家分享12个有关于JavaScript的小技巧。这些小技巧可能在你的实际工作中或许能帮助你解决一些问题。

分享12个非常实用的JavaScript小技巧

使用!!操作符转换布尔值

有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回true值。为了做这样的验证,我们可以使用!!操作符来实现是非常的方便与简单。对于变量可以使用!!variable做检测,只要变量的值为:0、null、" "、undefined或者NaN都将返回的是false,反之返回的是true。比如下面的示例:

function Account(cash) { 
  this.cash = cash; 
  this.hasMoney = !!cash; 
} 
var account = new Account(100.50); 
console.log(account.cash); // 100.50 
console.log(account.hasMoney); // true 
 
var emptyAccount = new Account(0); 
console.log(emptyAccount.cash); // 0 
console.log(emptyAccount.hasMoney); // false

在这个示例中,只要account.cash的值大于0,那么account.hasMoney返回的值就是true。

使用+将字符串转换成数字

这个技巧非常有用,其非常简单,可以交字符串数据转换成数字,不过其只适合用于字符串数据,否则将返回NaN,比如下面的示例:

function toNumber(strNumber) { 
  return +strNumber; 
} 
console.log(toNumber("1234")); // 1234 
console.log(toNumber("ACB")); // NaN

这个也适用于Date,在本例中,它将返回的是时间戳数字:

console.log(+new Date()) // 1461288164385 并条件符

如果你有一段这样的代码:

if (conected) {
login(); 
}

你也可以将变量简写,并且使用&&和函数连接在一起,比如上面的示例,可以简写成这样:

conected && login();

如果一些属性或函数存在于一个对象中,你也可以这样做检测,如下面的代码所示:

user && user.login();

使用||运算符

在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可以使用||操作符,并且将将默认值当做第二个参数传入。如果第一个参数返回的值为false,那么第二个值将会认为是一个默认值。如下面这个示例:

function User(name, age) { 
  this.name = name || "Oliver Queen"; 
  this.age = age || 27; 
} 
var user1 = new User(); 
console.log(user1.name); // Oliver Queen 
console.log(user1.age); // 27 
 
var user2 = new User("Barry Allen", 25); 
console.log(user2.name); // Barry Allen 
console.log(user2.age); // 25

在循环中缓存array.length

这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:

for(var i = 0; i < array.length; i++) { 
  console.log(array[i]); 
}

如果是一个小型数组,这样做很好,如果你要处理的是一个大的数组,这段代码在每次迭代都将会重新计算数组的大小,这将会导致一些延误。为了避免这种现象出现,可以将array.length做一个缓存:

var length = array.length; 
for(var i = 0; i < length; i++) { 
  console.log(array[i]); 
}

你也可以写在这样:

for(var i = 0, length = array.length; i < length; i++) { 
  console.log(array[i]); 
}

检测对象中属性

当你需要检测一些属性是否存在,避免运行未定义的函数或属性时,这个小技巧就显得很有用。如果你打算定些一些跨兼容的浏览器代码,你也可能会用到这个小技巧。例如,你想使用document.querySelector()来选择一个id,并且让它能兼容IE6浏览器,但是在IE6浏览器中这个函数是不存在的,那么使用这个操作符来检测这个函数是否存在就显得非常的有用,如下面的示例:

if ('querySelector' in document) { 
  document.querySelector("#id"); 
} else { 
  document.getElementById("id"); 
}

在这个示例中,如果document不存在querySelector函数,那么就会调用docuemnt.getElementById("id")。

获取数组中最后一个元素

Array.prototype.slice(begin,end)用来获取begin和end之间的数组元素。如果你不设置end参数,将会将数组的默认长度值当作end值。但有些同学可能不知道这个函数还可以接受负值作为参数。如果你设置一个负值作为begin的值,那么你可以获取数组的最后一个元素。如:

var array = [1,2,3,4,5,6]; 
console.log(array.slice(-1)); // [6] 
console.log(array.slice(-2)); // [5,6] 
console.log(array.slice(-3)); // [4,5,6]

数组截断

这个小技巧主要用来锁定数组的大小,如果用于删除数组中的一些元素来说,是非常有用的。例如,你的数组有10个元素,但你只想只要前五个元素,那么你可以通过array.length=5来截断数组。如下面这个示例:

var array = [1,2,3,4,5,6]; 
console.log(array.length); // 6 
array.length = 3; 
console.log(array.length); // 3 
console.log(array); // [1,2,3]

替换所有

String.replace()函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的/g来模拟replaceAll()函数功能:

var string = "john john"; 
console.log(string.replace(/hn/, "ana")); // "joana john" 
console.log(string.replace(/hn/g, "ana")); // "joana joana"

合并数组

如果你要合并两个数组,一般情况之下你都会使用Array.concat()函数:

var array1 = [1,2,3]; 
var array2 = [4,5,6]; 
console.log(array1.concat(array2)); // [1,2,3,4,5,6];

然后这个函数并不适合用来合并两个大型的数组,因为其将消耗大量的内存来存储新创建的数组。在这种情况之个,可以使用Array.pus().apply(arr1,arr2)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:

var array1 = [1,2,3]; 
var array2 = [4,5,6]; 
console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];

将NodeList转换成数组

如果你运行document.querySelectorAll(“p”)函数时,它可能返回DOM元素的数组,也就是NodeList对象。但这个对象不具有数组的函数功能,比如sort()、reduce()、map()、filter()等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用[].slice.call(elements)来实现:

var elements = document.querySelectorAll("p"); // NodeList 
var arrayElements = [].slice.call(elements); // Now the NodeList is an array 
var arrayElements = Array.from(elements); // This is another way of converting NodeList to Array

数组元素的洗牌

对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:

var list = [1,2,3]; 
console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]

总结

现在你学会了些有用的JavaScript小技巧。希望这些小技巧能在工作中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。如果你有一些优秀的JavaScript小技巧,欢迎在评论中与我们一起分享。

Javascript 相关文章推荐
采用CSS和JS,刚好我最近有个站点要用到下拉菜单!
Jun 26 Javascript
可缩放Reloaded-一个针对可缩放元素的复用组件
Mar 10 Javascript
jsTree树控件(基于jQuery, 超强悍)[推荐]
Sep 01 Javascript
JS常用表单验证方法总结
May 22 Javascript
JS获取图片lowsrc属性的方法
Apr 01 Javascript
Javascript中实现String.startsWith和endsWith方法
Jun 10 Javascript
JQuery日期插件datepicker的使用方法
Mar 03 Javascript
Vue 过渡实现轮播图效果
Mar 27 Javascript
Angular.Js中ng-include指令的使用与实现
May 07 Javascript
浅析JavaScript异步代码优化
Mar 18 Javascript
微信小程序如何再次获取用户授权的方法
May 10 Javascript
JavaScript中MutationObServer监听DOM元素详情
Nov 27 Javascript
分享10个优化代码的CSS和JavaScript工具
May 11 #Javascript
Bootstrap组件(一)之菜单
May 11 #Javascript
Bootstrap 组件之按钮(二)
May 11 #Javascript
jQuery验证插件validate使用详解
May 11 #Javascript
JQuery validate插件验证用户注册信息
May 11 #Javascript
jQuery validate验证插件使用详解
May 11 #Javascript
Jquery插件仿百度搜索关键字自动匹配功能
May 11 #Javascript
You might like
Laravel框架表单验证详解
2014/09/04 PHP
图文详解PHP环境搭建教程
2016/07/16 PHP
PHP7新特性foreach 修改示例介绍
2016/08/26 PHP
PHP封装请求类实例分析【基于Yii框架】
2019/10/17 PHP
点击广告后才能获得下载地址
2006/10/26 Javascript
jQuery 全选效果实现代码
2009/03/23 Javascript
JS 自动完成 AutoComplete(Ajax 查询)
2009/07/07 Javascript
jQuery AnythingSlider滑动效果插件
2010/02/07 Javascript
jQuery Validation实例代码 让验证变得如此容易
2010/10/18 Javascript
深入分析JQuery和JavaScript的异同
2014/10/23 Javascript
js实现在网页上简单显示时间的方法
2015/03/02 Javascript
JS实现的另类手风琴效果网页内容切换代码
2015/09/08 Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
2015/10/28 Javascript
利用jQuery来动态为属性添加或者删除属性的简单方法
2016/12/02 Javascript
Angular-Touch库用法示例
2016/12/22 Javascript
vue中关闭eslint的方法分析
2018/08/04 Javascript
js取小数点后两位四种方法
2019/01/18 Javascript
koa大型web项目中使用路由装饰器的方法示例
2019/04/02 Javascript
vue使用一些外部插件及样式的配置代码
2019/11/18 Javascript
使用python解析xml成对应的html示例分享
2014/04/02 Python
Python中线程编程之threading模块的使用详解
2015/06/23 Python
Python将json文件写入ES数据库的方法
2019/04/10 Python
python中正则表达式与模式匹配
2019/05/07 Python
python颜色随机生成器的实例代码
2020/01/10 Python
python scatter函数用法实例详解
2020/02/11 Python
django之导入并执行自定义的函数模块图解
2020/04/01 Python
如何把python项目部署到linux服务器
2020/08/26 Python
美国中小型企业领先的办公家具供应商:Office Designs
2016/11/26 全球购物
海信商城:海信电视、科龙空调、容声冰箱官方专卖
2017/02/07 全球购物
销售高级职员求职信
2013/10/29 职场文书
杠杆的科学教学反思
2014/01/10 职场文书
初中语文教学反思
2014/02/02 职场文书
房地产开发项目建议书
2014/05/16 职场文书
大学生安全责任书
2014/07/25 职场文书
2014年学习委员工作总结
2014/11/14 职场文书
python自动化操作之动态验证码、滑动验证码的降噪和识别
2021/08/30 Python