词条信息

admin
admin
超级管理员
最近编辑者 发短消息   

相关词条

热门词条

更多>>
什么是端口?到底是做什么的呢?
端口一般指两种,一种是硬件比如路由器或者交换机的插网线的端口,一种是软件的逻辑的概念,比如http的80端口!...
7种进阶方法让你快速测试端口连通性
Ping是Windows、Linux和Unix系统下的一个检查网络连通性的命令工具,对于大部分互联网用户来说很...
电脑开机,总需要按F1,是什么原因造成的?
一.主板掉电这个说法是行业内的叫法了,一般是主板的CMOS电池没电了导致的。也是最常见的一种提示你按F1的提示...
社保降费对个人有什么影响?
下调城镇职工基本养老保险单位缴费比例是政府给企业发的一个大红包,特别是对于企业来说是一个利好,但是对个人来说有...
车辆“出险”对下年保费的影响,到底有多大?
【出险对交强险的影响】【出险对商业险的影响】车辆“出险”对下年保费的影响,到底有多大?这里有必要先提下车险第三...

精选图集

更多>>
简易百科旧版 >>所属分类 >> 程序开发    JavaScript   

十二个很实用的JavaScript小技巧

标签: JavaScript 网站开发

顶[0] 发表评论(0) 编辑词条

有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回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")。 

一位好的Web前端开发工程师在知识体系上既要有广度,又要有深度,所以很多大公司即使出高薪也很难招聘到理想的前端开发工程师。那么如何系统的学习企业实用的web前端技术呢,为此建立了一个web前端的直播上课学习扣扣裙,web前端前面数字是四一八,web前端中间的数字是三五五,web前端最后是五三一,将数字连接起来就是了。真正想要学习的可以进入,打酱油的就不要浪费大家的时间了。现在说的重点不在于讲解技术,而是更侧重于对技巧的讲解。技术非黑即白,只有对和错,而技巧则见仁见智。 

获取数组中最后一个元素 编辑本段回目录



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小技巧,欢迎在评论中与我们一起分享。


 

 

附件列表


按字母顺序浏览:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

→我们致力于为广大网民解决所遇到的各种电脑技术问题
 如果您认为本词条还有待完善,请 编辑词条

上一篇揭露微信转发文章赚钱的一些骗局
下一篇js获取随机字符串的方法

0
1. 本站部分内容来自互联网,如有任何版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
2. 本站内容仅供参考,如果您需要解决具体问题,建议您咨询相关领域专业人士。
3. 如果您没有找到需要的百科词条,您可以到百科问答提问或创建词条,等待高手解答。

关于本词条的提问

查看全部/我要提问>>