给大家分享12个或许能在实际工作中帮助你解决一些问题的JavaScript的小技巧
来源:互联网 发布:刷单网站源码 编辑:程序博客网 时间:2024/04/29 11:59
!!
操作符转换布尔值有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回true
值。为了做这样的验证,我们可以使用!!
操作符来实现是非常的方便与简单。对于变量可以使用!!variable
做检测,只要变量的值为:0
、null
、" "
、undefined
或者NaN
都将返回的是false
,反之返回的是true
。比如下面的示例:
01
function
Account(cash) {
02
this.cash = cash;
03
this.hasMoney = !!cash;
04
}
05
var
account =
new
Account(100.50);
06
console.log(account.cash);
// 100.50
07
console.log(account.hasMoney);
// true
08
09
var
emptyAccount =
new
Account(0);
10
console.log(emptyAccount.cash);
// 0
11
console.log(emptyAccount.hasMoney);
// false
在这个示例中,只要account.cash
的值大于0
,那么account.hasMoney
返回的值就是true
。
使用+
将字符串转换成数字
这个技巧非常有用,其非常简单,可以交字符串数据转换成数字,不过其只适合用于字符串数据,否则将返回NaN
,比如下面的示例:
1
function
toNumber(strNumber) {
2
return
+strNumber;
3
}
4
console.log(toNumber(
"1234"
));
// 1234
5
console.log(toNumber(
"ACB"
));
// NaN
这个也适用于Date
,在本例中,它将返回的是时间戳数字:
1
console.log(+
new
Date
())
// 1461288164385
并条件符
如果你有一段这样的代码:
1
if
(conected) {
2
login();
3
}
你也可以将变量简写,并且使用&&
和函数连接在一起,比如上面的示例,可以简写成这样:
1
conected && login();
如果一些属性或函数存在于一个对象中,你也可以这样做检测,如下面的代码所示:
1
user && user.login();
使用||
运算符
在ES6中有默认参数这一特性。为了在老版本的浏览器中模拟这一特性,可以使用||
操作符,并且将将默认值当做第二个参数传入。如果第一个参数返回的值为false
,那么第二个值将会认为是一个默认值。如下面这个示例:
01
function
User(name, age) {
02
this.name = name ||
"Oliver Queen"
;
03
this.age = age || 27;
04
}
05
var
user1 =
new
User();
06
console.log(user1.name);
// Oliver Queen
07
console.log(user1.age);
// 27
08
09
var
user2 =
new
User(
"Barry Allen"
, 25);
10
console.log(user2.name);
// Barry Allen
11
console.log(user2.age);
// 25
在循环中缓存array.length
这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:
1
for
(
var
i = 0; i <
array
.length; i++) {
2
console.log(
array
[i]);
3
}
如果是一个小型数组,这样做很好,如果你要处理的是一个大的数组,这段代码在每次迭代都将会重新计算数组的大小,这将会导致一些延误。为了避免这种现象出现,可以将
array.length
做一个缓存:
1
var
length =
array
.length;
2
for
(
var
i = 0; i < length; i++) {
3
console.log(
array
[i]);
4
}
你也可以写在这样:
1
for
(
var
i = 0, length =
array
.length; i < length; i++) {
2
console.log(
array
[i]);
3
}
检测对象中属性
当你需要检测一些属性是否存在,避免运行未定义的函数或属性时,这个小技巧就显得很有用。如果你打算定些一些跨兼容的浏览器代码,你也可能会用到这个小技巧。例如,你想使用
document.querySelector()
来选择一个id
,并且让它能兼容IE6浏览器,但是在IE6浏览器中这个函数是不存在的,那么使用这个操作符来检测这个函数是否存在就显得非常的有用,如下面的示例:
1
if
(
'querySelector'
in document) {
2
document.querySelector(
"#id"
);
3
}
else
{
4
document.getElementById(
"id"
);
5
}
在这个示例中,如果
document
不存在querySelector
函数,那么就会调用docuemnt.getElementById("id")
。
获取数组中最后一个元素
Array.prototype.slice(begin,end)
用来获取begin
和end
之间的数组元素。如果你不设置end
参数,将会将数组的默认长度值当作end
值。但有些同学可能不知道这个函数还可以接受负值作为参数。如果你设置一个负值作为begin
的值,那么你可以获取数组的最后一个元素。如:
1
var
array
= [1,2,3,4,5,6];
2
console.log(
array
.slice(-1));
// [6]
3
console.log(
array
.slice(-2));
// [5,6]
4
console.log(
array
.slice(-3));
// [4,5,6]
数组截断
这个小技巧主要用来锁定数组的大小,如果用于删除数组中的一些元素来说,是非常有用的。例如,你的数组有
10
个元素,但你只想只要前五个元素,那么你可以通过array.length=5
来截断数组。如下面这个示例:
1
var
array
= [1,2,3,4,5,6];
2
console.log(
array
.length);
// 6
3
array
.length = 3;
4
console.log(
array
.length);
// 3
5
console.log(
array
);
// [1,2,3]
替换所有
String.replace()
函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的/g
来模拟replaceAll()
函数功能:
1
var
string =
"john john"
;
2
console.log(string.replace(/hn/,
"ana"
));
// "joana john"
3
console.log(string.replace(/hn/g,
"ana"
));
// "joana joana"
合并数组
如果你要合并两个数组,一般情况之下你都会使用
Array.concat()
函数:
1
var
array1 = [1,2,3];
2
var
array2 = [4,5,6];
3
console.log(array1.concat(array2));
// [1,2,3,4,5,6];
然后这个函数并不适合用来合并两个大型的数组,因为其将消耗大量的内存来存储新创建的数组。在这种情况之个,可以使用
Array.pus().apply(arr1,arr2)
来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:
1
var
array1 = [1,2,3];
2
var
array2 = [4,5,6];
3
console.log(array1.push.apply(array1, array2));
// [1,2,3,4,5,6];
将NodeList
转换成数组
NodeList
转换成数组如果你运行
document.querySelectorAll(“p”)
函数时,它可能返回DOM元素的数组,也就是NodeList
对象。但这个对象不具有数组的函数功能,比如sort()
、reduce()
、map()
、filter()
等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用[].slice.call(elements)
来实现:
1
var
elements = document.querySelectorAll(
"p"
);
// NodeList
2
var
arrayElements = [].slice.call(elements);
// Now the NodeList is an array
3
var
arrayElements = Array.from(elements);
// This is another way of converting NodeList to Array
数组元素的洗牌
对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:
1
var
list = [1,2,3];
2
console.log(list.sort(
function
() { Math.random() - 0.5 }));
// [2,1,3]
总结
现在你学会了些有用的JavaScript小技巧。希望这些小技巧能在工作中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。如果你有一些优秀的JavaScript小技巧,欢迎在评论中与我们一起分享。
写在最后:FOR Freedom 看看外边的世界,以及IT这一行,少不了去Google查资料,最后,安利一个V——PN代理。一枝红杏 VPN,去Google查资料是绝对首选,连接速度快,使用也方便。我买的是99¥一年的,通过这个链接(http://my.yizhihongxing.com/aff.php?aff=2509)注册后输上会员中心得优惠码,平摊下来,每月才7块钱,特实惠。
本文标签: JavaScript小技巧 JavaScript JavaScript数组处理 JavaScript正则表达式 JavaScript函数
转自 SUN'S BLOG - 专注互联网知识,分享互联网精神!
原文地址 : 《给大家分享12个或许能在实际工作中帮助你解决一些问题的JavaScript的小技巧》
相关阅读:《Aaron Swartz – 互联网天才开挂的人生历程:每时每刻都问自己,现在这世界有什么最重要的事是我能参与去做的?》
相关阅读:《网站环境apache + php + mysql 的XAMPP,如何实现一个服务器上配置多个网站?》相关阅读:《什么是工程师文化?各位工程师是为什么活的?作为一个IT或互联网公司为什么要工程师文化?》
相关阅读: 对程序员有用:2017最新能上Google的hosts文件下载及总结网友遇到的各种hosts问题解决方法及配置详解
相关阅读: 《春节将至,又到了评绩效拿年终奖的时候!程序员绩效KPI 这个弥久历史谜题该怎么算呢?》
相关BLOG:SUN’S BLOG - 专注互联网知识,分享互联网精神!去看看:www.whosmall.com
- 给大家分享12个或许能在实际工作中帮助你解决一些问题的JavaScript的小技巧
- 分享10个帮助你编写更加简洁javascript代码的小技巧
- Android 中关于属性动画的一些思考,或许能为你解决一定的性能问题
- 分享公积金按揭心得,希望能给大家一些帮助!
- 关于C#更新Access数据库时发现的一个没有任何技术含量的问题,给大家分享,希望能给大家帮助
- 工作中常用的一些javascript的小技巧
- 工作中常用的一些javascript小技巧(二)
- 工作中常用的一些javascript小技巧(三)
- 工作中常用的mysql语句分享给大家
- 给大家分享5个关于迅猛增长的实际例子
- 给大家分享5个关于迅猛增长的实际例子
- 单片机 DS1302 痛苦的调试过程,把我的经验教训分享给大家,希望能给后来者一点帮助
- 我在面试时问到的问题 或许对你有帮助
- 程序员拍婚纱照的细节,分享给大家希望对你有帮助
- 实际工作中遇到的技术难题与大家交流(工作流条件表达式计算部分),希望技术高手能给于指点
- 实际工作中遇到的技术难题与大家交流(工作流条件表达式计算部分),希望技术高手能给于指点
- 好长时间上不了博客,我还以为因为我发表抗日言论账户被删了,编程中好多新经验新发现不能拿出来和朋友们分享,那个急呀。以下是我在工作中积累的一些经验和解决的一些问题,希望能对大家有一点帮助。
- 一个公务员工作七年后的肺腑之言”——给想考公务员的XDJM们看看,或许能有帮助
- 盘点类似于GitHub的代码托管平台码云的2016年度热门项目排行榜TOP 50
- java多线程入门详解
- S3C2440--存储管理器
- Android开发工程师应该知道的50个开发秘诀、技巧和资源分享
- jqGrid 各种参数 详解
- 给大家分享12个或许能在实际工作中帮助你解决一些问题的JavaScript的小技巧
- 给大家分享2017支付宝扫福字集五福卡红包攻略技术:缺敬业福友善福的速看!
- Spark Streaming的foreachRDD算子的正确使用
- Spring Cloud生态圈简介
- 盘点优秀的程序员之所以优秀的原因:所以优秀的程序员几乎都喜欢命令行
- 如何使用JavaScript快速的创建一种常用类型的导航组件:sidebar
- UVA 1471 Defense Lines (STL + 二分)
- 算法训练 数字三角形
- TCP/IP协议入门(一)--阮一峰