在这篇文章中将给大家分享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小技巧,欢迎在评论中与我们一起分享。
本文根据@Caio Ribeiro Pereira的《12 Extremely Useful Hacks for JavaScript》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处:https://blog.jscrambler.com/12-extremely-useful-hacks-for-javascript/。
原文出处:http://www.w3cplus.com/javascript/12-extremely-useful-hacks-for-javascript.html
相关推荐
在这篇文章中,我们将分享 12 个特别有用的 JavaScript 小技巧,这些小技巧可能在你的实际工作中或许能帮助你解决一些问题。 用法!!操作符转换布尔值 在 JavaScript 中,我们经常需要对一个变量检查其是否存在或者...
- 使用`Promise`配合`setTimeout`可以创建一个延迟执行的任务,这对于异步操作中的延时处理非常有用。 5. **打乱数组** - 通过`sort()`方法结合随机数,可以实现数组元素的随机排序,达到洗牌的效果。这种方法...
以下是根据给定文件中提供的部分知识内容,详细解说的12个JavaScript技巧: 1. 使用双重否定运算符(!!)转换变量为布尔值 在JavaScript中,我们可以使用布尔类型转换来检查变量是否有效。使用双重否定运算符(!!...
"javascript技巧精心收集"这个主题包含了一系列关于JavaScript编程的实用技巧和资源,旨在帮助开发者提升技能和效率。以下是一些从提供的文件名中提炼出的关键知识点: 1. **jsp技巧.txt**:这可能涉及到JavaServer...
在本文中,我们将深入探讨几个有用的JavaScript技巧,包括整数操作、函数重写、数字交换、对象特性以及if语句的变形。 首先,关于JavaScript中的整数操作,我们可以利用`|0`或`~~`运算符快速将浮点数转换为整数。...
这对于数据封装和实现私有变量非常有用。 在绘图方面,JavaScript通常与HTML5的Canvas API结合使用。Canvas提供了一组方法和属性,允许开发者在网页上绘制图形。例如,`fillRect()`用于画矩形,`beginPath()`和`...
根据提供的文件信息,这里将对其中提及的部分JavaScript技巧进行详细解释和扩展,旨在帮助读者更好地理解和运用这些技巧。 ### 1. 禁用右键菜单 ```plaintext oncontextmenu="window.event.returnValue=false" ...
13. **获取控件的绝对位置**:使用JavaScript或VBScript可以获取元素的绝对位置,这对于布局调整或交互设计非常有用。 14. **光标定位在文本框末尾**:通过创建和选择文本范围,可以将光标始终定位在文本框的最后。...
以上是JavaScript中的一些实用技巧,它们涵盖了用户交互、页面保护、元素操作等多个方面,能帮助开发者提高代码质量并提供更好的用户体验。在实际开发中,根据项目需求和兼容性考虑,灵活运用这些技巧能够提升网站的...
**技巧12:** 在删除操作前弹出确认对话框。 ```html <a href="javascript:if (confirm('确定要删除吗?')) location='boos.asp?&areyou=删除&page=1'">删除 ``` 这种设计可以防止用户误删重要数据。 #### 八、...
在跨页面的数据传递中,`window.name`属性是一个非常有用的功能。它可以用来存储字符串数据,并且在页面刷新或跳转后仍然保留该数据。这使得它成为一种简单的数据持久化方案,特别是在不需要服务器端交互的情况下。 ...
7. **JavaScript编程的10个有用小技巧**和**12个特别有用的JavaScript小技巧【推举】**:这两篇文章分别分享了10个和12个实用的JavaScript编程技巧,是进阶学习的好资源。 总的来说,掌握生成HTML元素的技巧对...
- **应用场景**:提供一个方便用户查看源代码的方式,对于开发者调试页面非常有用。 #### 10. 删除确认提示 - **代码示例**: ```html <a href="javascript:if (confirm('确实要删除吗?')) location='boos.ASP...
5. **正则表达式**:正则表达式在JavaScript中用于文本匹配和替换,对于数据验证和字符串处理非常有用。 6. **ES6新特性**:包括箭头函数、解构赋值、模板字符串、let和const等,它们提供了更简洁、更安全的编码...
本文将深入探讨《18个JavaScript技巧:编写简洁高效的代码》PDF文档中提及的一些关键技巧,并详细解释每个技巧的实际应用及背后原理。这些技巧旨在帮助开发者提高代码质量和效率。 #### 1. 箭头函数简化函数声明 ...
本文将基于“JavaScript小技巧一箩筐”这一主题,深入探讨一系列实用的JavaScript技巧,涵盖事件处理、DOM操作、表单控制、定时器使用等多个方面,旨在帮助开发者提升代码效率与网站性能。 #### 事件处理与键盘操作...
这个名为“100个+非常犀利的javascript”的压缩包,显然是一份宝贵的资源集合,包含了许多实用且创新的JavaScript代码示例。这些示例旨在帮助开发者在Web项目中实现各种炫酷效果,提高用户体验。 首先,我们要了解...
以上就是根据提供的文件内容整理的一些JavaScript小技巧,这些技巧覆盖了事件处理、DOM操作、表单与链接操作、特殊字符处理等多个方面,希望对大家有所帮助。在实际开发中,灵活运用这些技巧可以极大地提高工作效率...