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

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

class Account {  constructor(cash) {    this.cash = cash;    this.hasMoney = !!cash;  }}let account = new Account(10.2);console.log(account.cash); //10.2console.log(account.hasMoney); //truelet account2 = new Account(0);console.log(account2.cash); //0console.log(account2.hasMoney); //false

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

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

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

class ToNumber{    constructor(num){        this.num = num    };    to(){        return +this.num    }}let num1 = new ToNumber("10");let num01 = num1.to();console.log(num01+1); //返回11let num2 = new ToNumber("10d");let num02 = num2.to();console.log(num02); //返回NaN

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

console.log(+new Date()); //返回的是当前时间的时间戳

并条件符

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

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")。

使用按位异或|进行取整

按位异或操作符|有体格尿性,就是两边只要是0的话才为0,有一个不为0的数返回的就是整数

let num = 2.2 | 0;console.log(num); //返回2

  

获取数组中最后一个元素

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.push().apply(arr1,arr2)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:

var array1 = [1,2,3];
var array2 = [4,5,6]; array1.push.apply(array1, array2); //6 console.log(array1);// [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() { return Math.random() - 0.5 })); // [2,1,3]

转载于:https://www.cnblogs.com/mmykdbc/p/8073339.html

13个非常实用的JavaScript小技巧相关推荐

  1. 常用的一些javascript小技巧(收藏http://www.car371.com/article.asp?id=13)

    常用的一些javascript小技巧 作者:隆轩 日期:2005-12-21 字体大小: 小 中 大 //事件源对象 event.srcElement.tagName event.srcElement ...

  2. 11个不常被提及的JavaScript小技巧

    这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日常工作中经常出现,但是我们又很容易忽略. 1.过滤唯一值 Set类型是在 ES6中新增的,它类似于数组,但 ...

  3. 【译】5 个你需要知道的 JavaScript 小技巧

    JavaScript 是目前最流行的编程语言之一.就像其他任何编程语言一样,它也有很多小技巧,从今天开始你就可以使用它们 大多数程序员都应该每天训练这些小技巧,直到熟能生巧. 在这篇文章中,我们将一起 ...

  4. javascript小技巧-500例

    搜集的一些javascript小技巧!事件源对象 event.srcElement.tagName event.srcElement.type 捕获释放 event.srcElement.setCap ...

  5. 一些学习中常被忽略的 JavaScript 小技巧

    点击上方"IT平头哥联盟",选择"置顶或者星标" 一起进步- 作者:冷星 https://segmentfault.com/a/1190000018897633 ...

  6. 11个教程中不常被提及的JavaScript小技巧

    Java面试笔试面经.Java技术每天学习一点 Java面试 关注不迷路 作者:冷星 来源:https://segmentfault.com/a/1190000018897633 这次我们主要来分享1 ...

  7. 11个 教程中不常被提及的 JavaScript 小技巧

    作者:冷星 链接:https://segmentfault.com/a/1190000018897633(点击尾部阅读原文前往) 有一些在日常工作中经常出现却容易被忽略的JavaScript小技巧,作 ...

  8. javascript小技巧!

    搜集的一些javascript小技巧! 事件源对象 event.srcElement.tagName event.srcElement.type 捕获释放 event.srcElement.setCa ...

  9. 搜集的一些javascript小技巧!

    搜集的一些javascript小技巧! 事件源对象 event.srcElement.tagName event.srcElement.type 捕获释放 event.srcElement.setCa ...

最新文章

  1. Pair Project: API设计 by Xiao Li and Yishi Xing
  2. Option,Some,None
  3. Python 获取父级文件夹的名字
  4. Puppent 介绍原理及安装
  5. android5.1+xposed卡刷包,一加5 7.1 ROM刷机包 最终版王者高帧率极速吃鸡超多自定义Xposed...
  6. 网易云音乐网站音乐下载
  7. CentOS7中安装PostgreSQL客户端
  8. Linux运维工程师面试知识点汇总(二)
  9. 第一阶段✦第二章☞信息系统集成及服务管理
  10. 戴尔台式计算机主板型号,如何查看戴尔主板型号 查看戴尔主板型号的步骤
  11. 三脚架代表人生_如何选择和使用三脚架
  12. OSS简单上传下载整理
  13. httprunner-2-linux下搭建hrun(下)
  14. 射频信号源及射频信号测试接口案例-纳米软件
  15. 输入5*5阶的矩阵,编程实现:A.求两条对角线上的各元素之和;B.求两条对角线上行、列下标均为偶数的各元素之积。
  16. ESD静电保护(ESD器件保护原理及选型)
  17. 新纪元期货:投资远离骗局
  18. Mapper代理文件实现
  19. 尚硅谷Java大厂面试题第2季学习笔记(垃圾收集器部分)
  20. VRay动画渲染闪烁的原因和解决办法

热门文章

  1. sketch设置字体技巧(二)---通过组合法重新组建字体
  2. Delphi 7 定义你自己的事件
  3. 怎样做地推,转化率提高20倍?
  4. 大数据与Hadoop的区别
  5. 电动车爬坡时究竟应该用最快档还是用最慢档?
  6. 设计一款知识性产品需要考虑十二个基本问题
  7. 本科毕业找不到工作,是怎样的体会
  8. 为什么感觉赚100万很难?
  9. 做自媒体花式撸收益?
  10. 社区团购就是好啊,为何网上那多人去喷呢?