《2022年JavaScript开发者经常忽略或误用的7个知识点.pdf》由会员分享,可在线阅读,更多相关《2022年JavaScript开发者经常忽略或误用的7个知识点.pdf(4页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、JavaScript开发者经常忽略或误用的7 个知识点JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它。昨天我们将这些模式应用到了JavaScript 框架中, 今天这些框架又驱动了我们的Web 应用程序。很多新手开发者被各种强大的JavaScript 框架吸引进来,但他们却忽略了框架身后浩如星海的JavaScript 实用技巧。本文将为你呈献其中7 个基础知识点。1. 在 String.prototype.replace 方法中使用/g 和 /i 标志位令很多JavaScript 初学者意外的是,字符串的replace 方法并不会替换所有匹配的子串 而
2、仅仅替换第一次匹配。当然JavaScript 老手们都知道这里可以使用正则表达式,并且需要加上一个全局标志位(/g) :Javascript代码1./ Mistake2./ 踩到坑了3.var str = David is an Arsenal fan, which means David is great; 4.str.replace(David, Darren); / Darren is an Arsenal fan, which means David is great5.6./ Desired7./ 符合预期8.str.replace(/David/g, Darren); / Darr
3、en is an Arsenal fan, which means Darren is great另一个基本的逻辑错误就是在大小写不敏感的校验场合(字母可大写可小写)没有忽略大小写,此时/i 标志位就很实用:Javascript代码1.str.replace(/david/gi, Darren); / Darren will always be an Arsenal fan, which means Darren will always be great(译注:上面这段例程我没有看懂用意,可能是注释有误吧 )每个JavaScript 开发者都曾踩过这两个标志位的坑 因此别忘了在适当的时候用上它
4、们!2. 类数组对象和Array.prototype.slice 方法数组的slice 方法通常用来从一个数组中抽取片断。但很多开发者不了解的是,这个方法还可以用来将 “ 类数组 ” 元素(比如arguments 参数列表、节点列表和属性列表)转换成真正的 数 组 :( 译 注 : DOM 元 素 的 属 性 列 表 通 过attributes属 性 获 取 , 比 如document.body.attributes。 )Javascript代码1.var nodesArr = Array.prototype.slice.call(document.querySelectorAll(div);
5、 2./ true array of DIVs3./ 得到一个由 div 元素组成的 “ 真正的 ” 数组精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 1 页,共 4 页 - - - - - - - - - - 4.5.var argsArr = Array.prototype.slice.call(arguments); 6./ changes arguments to true array7./ 把 arguments 转换成一个 “ 真正的 ” 数组8.你还可以使用一次简单的 slice 调用来克
6、隆一个数组:9.var clone = myArray.slice(0); / naive clone10./ 浅克隆(译注:这里的参数0 也可以省略,我估计undefined 被 slice 方法自动转换为0 了吧。 )Array.prototype.slice 绝对是JavaScript 世界中的一玫珍宝,但 JavaScript 初学者们显然还没有意识到它的全部潜力。3. Array.prototype.sort 方法数组的sort 方法 远远没有被充分利用,而且可能比开发者们想像的更加强大。很多开发者可能觉得sort 方法可以用来做这种事情:Javascript代码1.1, 3, 9,
7、 2.sort(); 2./ Returns: 1, 2, 3, 93./ 返回 1, 2, 3, 9 这没错,但它还有更强大的用法,比如这样:Javascript代码1. 2. name: Robin Van PurseStrings, age: 30 , 3. name: Theo Walcott, age: 24 , 4. name: Bacary Sagna, age: 28 5.sort(function(obj1, obj2) 6./ Ascending: first age less than the previous7./ 实现增序排列:前者的 age 小于后者8.return
8、 obj1.age - obj2.age; 9.); 10./ Returns: 11./ 12./ name: Theo Walcott, age: 24 ,13./ name: Bacary Sagna, age: 28 ,14./ name: Robin Van PurseStrings, age: 30 15./ 你不仅可以对简单类型的数组项进行排序,可以通过属性来排序对象。如果哪天服务器端发来一段JSON 数据,而且其中的对象需要排序,你可别忘了这一招!4. 用 length 属性来截断数组几乎所有开发者都踩过JavaScript 的这个坑 “ 传对象只是传引用” 。开发者们经常会试
9、精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 2 页,共 4 页 - - - - - - - - - - 图 把一个数组清空,但实际上却错误地创建了一个新数组。Javascript代码1.var myArray = yourArray = 1, 2, 3; 2.3./ :(4./ 囧5.myArray = ; / yourArray is still 1, 2, 36./ yourArray 仍然是 1, 2, 37.8./ The right way, keeping reference9./ 正确的
10、方法是保持引用10.myArray.length = 0; / yourArray and myArray both 11./ yourArray 和 myArray(以及其它所有对这个数组的引用)都变成 了坑里的人们终于明白, 原来传对象只是在传引用。因此当我把myArray 重新赋值为 时,确实会创建出一个新的空数组,但其它对老数组的引用仍然没变!大坑啊! 还是换用截断的方法吧,少年。5. 使用 push 来合并数组在上面的第2 节里,我展示了数组的slice 和 apply 方法所能组合出的几个小妙招,所以对于数组方法的其它技巧,你应该已经做好心理准备了吧。这次我们使用push 方法来合
11、并数组:Javascript代码1.var mergeTo = 4,5,6; 2.var mergeFrom = 7,8,9; 3.4.Array.prototype.push.apply(mergeTo, mergeFrom); 5.6.mergeTo; / is: 4, 5, 6, 7, 8, 9这是一项不为人知的小技巧,简单的原生方法就可以实现数组合并这样的常见任务。(译注:这个方法的巧妙之外不仅在于push 方法可以接收多个参数,还涉及到apply 方法的第二个参数的用法。 )6. 高效探测功能特性和对象属性很多时候开发者们会像下面这样来探测浏览器的某个特性:Javascript代码1
12、.if (navigator.geolocation) 2./ Do some stuff3./ 在这里干点事情4. 当然这可以正常工作,但它并不一定有很好的效率。因为这个对象探测方法会在浏览器中初精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 3 页,共 4 页 - - - - - - - - - - 始化资源。 在过去, 上面的代码片断可能会在某些浏览器下导致内存泄露。更好、 更快的方法是检查对象是否包含某个键名:Javascript代码1.if ( geolocationin navigator)
13、2./ Do some stuff3./ 在这里干点事情4. 键名检查十分简单,而且可以避免内存泄露。另外请注意,如果这个属性的值是假值,那么前一种探测方式将会得到“ 否” 的结果,并不能真正探测出这个键名是否存在。7. 事件对象的preventDefault 和 stopPropagation 方法很多时候,当一个动作元素(比如链接)被点击时,会触发某个功能。显然我们并不希望点击 链接 时浏 览器 顺着 这个 链接 跳转 ,于 是我 们会 习惯 性地 使用JavaScript 类 库的Event.stop 方法:Javascript代码1.$( a.trigger).on(click, fu
14、nction(e) 2. e.stop(); 3.4./ Do more stuff5./ 在这里干点事情6.); (译注:不知道哪个类库有这个方法,估计其作用相当于return false; 吧。语法看起来像jQuery , 但jQuery 并 没 有 这 个 方 法 , 而 且jQuery 是 支 持e.preventDefault 和e.stopPropagation 方法的。)这个懒方法有一个问题,它不仅阻止了浏览器的默认动作,同时也阻止了事件继续冒泡。这意味着元素上绑定的其它事件监听器将不会被触发,因为它们根本就不知道有事件发生。此时不妨使用preventDefault 吧!JavaScript 老鸟们看到这篇文章可能会说“ 我早知道了 ” ,但说不定什么时候,他们就会在某一点上栽跟头。提醒大家留意JavaScript 中的各种小细节,失之毫厘谬以千里啊!精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 4 页,共 4 页 - - - - - - - - - -