原文转自:http://bbs.html5cn.org/thread-83442-1-1.html

1. 在 String.prototype.replace 方法中使用 /g 和 /i标志位

令很多 JavaScript 初学者意外的是,字符串的 replace 方法并不会 替换所有匹配的子串——而仅仅替换第一次匹配。当然 JavaScript 老手们都知道这里可以使用正则表达式,并且需要加上一个全局标志位(/g):

  1. // Mistake
  2. // 踩到坑了
  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 great"
  5. // Desired
  6. // 符合预期
  7. str.replace(/David/g, "Darren"); // "Darren is an Arsenal fan, which means Darren is great"

复制代码

另一个基本的逻辑错误就是在大小写不敏感的校验场合(字母可大写可小写)没有忽略大小写,此时 /i 标志位就很实用:

  1. str.replace(/david/gi, "Darren"); // "Darren will always be an Arsenal fan, which means Darren will always be great"

复制代码

(译注:上面这段例程我没有看懂用意,可能是注释有误吧……) 
每个 JavaScript 开发者都曾踩过这两个标志位的坑——因此别忘了在适当的时候用上它们!

2. 类数组对象和 Array.prototype.slice 方法

数组的 slice 方法通常用来从一个数组中抽取片断。但很多开发者不了解的是,这个方法还可以用来将“类数组”元素(比如 arguments 参数列表、节点列表和属性列表)转换成真正的数组:(译注:DOM 元素的属性列表通过 attributes属性获取,比如 document.body.attributes。)

  1. var nodesArr = Array.prototype.slice.call(document.querySelectorAll("div"));
  2. // "true" array of DIVs
  3. // 得到一个由 div 元素组成的“真正的”数组
  4. var argsArr = Array.prototype.slice.call(arguments);
  5. // changes arguments to "true" array
  6. // 把 arguments 转换成一个“真正的”数组
  7. 你还可以使用一次简单的 slice 调用来**一个数组:
  8. var clone = myArray.slice(0); // naive clone
  9. // 浅**

复制代码

(译注:这里的参数 0 也可以省略,我估计 undefined 被 slice 方法自动转换为 0 了吧。)

Array.prototype.slice 绝对是 JavaScript 世界中的一玫珍宝,但 JavaScript 初学者们显然还没有意识到它的全部潜力。

3. Array.prototype.sort 方法

数组的 sort 方法 远远没有被充分利用,而且可能比开发者们想像的更加强大。很多开发者可能觉得 sort 方法可以用来做这种事情:

  1. [1, 3, 9, 2].sort();
  2. // Returns: [1, 2, 3, 9]
  3. // 返回 [1, 2, 3, 9]

复制代码

……这没错,但它还有更强大的用法,比如这样:

  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 previous
  7. // 实现增序排列:前者的 age 小于后者
  8. return 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 的这个坑——“传对象只是传引用”。开发者们经常会试图 把一个数组清空,但实际上却错误地创建了一个新数组。

  1. var myArray = yourArray = [1, 2, 3];
  2. // :(
  3. // 囧
  4. myArray = []; // `yourArray` is still [1, 2, 3]
  5. // `yourArray` 仍然是 [1, 2, 3]
  6. // The right way, keeping reference
  7. // 正确的方法是保持引用
  8. myArray.length = 0; // `yourArray` and `myArray` both [ ]
  9. // `yourArray` 和 `myArray`(以及其它所有对这个数组的引用)都变成 [ ] 了

复制代码

坑里的人们终于明白,原来传对象只是在传引用。因此当我把 myArray 重新赋值为 [] 时,确实会创建出一个新的空数组,但其它对老数组的引用仍然没变!大坑啊!还是换用截断的方法吧,少年。

5. 使用 push 来合并数组

在上面的第 2 节里,我展示了数组的 slice 和 apply 方法所能组合出的几个小妙招,所以对于数组方法的其它技巧,你应该已经做好心理准备了吧。这次我们使用 push 方法来合并数组:

  1. var mergeTo = [4,5,6];
  2. var mergeFrom = [7,8,9];
  3. Array.prototype.push.apply(mergeTo, mergeFrom);
  4. mergeTo; // is: [4, 5, 6, 7, 8, 9]

复制代码

这是一项不为人知的小技巧,简单的原生方法就可以实现数组合并这样的常见任务。(译注:这个方法的巧妙之外不仅在于 push 方法可以接收多个参数,还涉及到 apply 方法的第二个参数的用法。)

6. 高效探测功能特性和对象属性

很多时候开发者们会像下面这样来探测浏览器的某个特性:

  1. if(navigator.geolocation) {
  2. // Do some stuff
  3. // 在这里干点事情
  4. }

复制代码

键名检查十分简单,而且可以避免内存泄露。另外请注意,如果这个属性的值是假值,那么前一种探测方式将会得到“否”的结果,并不能真正探测出这个键名是否存在。

7. 事件对象的 preventDefault 和 stopPropagation 方法

很多时候,当一个动作元素(比如链接)被点击时,会触发某个功能。显然我们并不希望点击链接时浏览器顺着这个链接跳转,于是我们会习惯性地使用 JavaScript 类库的 Event.stop 方法:

  1. $("a.trigger").on("click", function(e) {
  2. e.stop();
  3. // Do more stuff
  4. // 在这里干点事情
  5. });

复制代码

(译注:不知道哪个类库有这个方法,估计其作用相当于 return false; 吧。语法看起来像 jQuery,但 jQuery 并没有这个方法,而且 jQuery 是支持 e.preventDefault 和 e.stopPropagation 方法的。)

这个懒方法有一个问题,它不仅阻止了浏览器的默认动作,同时也阻止了事件继续冒泡。这意味着元素上绑定的其它事件**将不会被触发,因为它们根本就不知道有事件发生。此时不妨使用 preventDefault 吧!

via:http://www.cnblogs.com/xiaochao1 ... /07/23/3862963.html

【转】JavaScript 经常忽略的 7 个基础知识点的更多相关文章

  1. JavaScript 经常忽略的 7 个基础知识点

    1. 在 String.prototype.replace 方法中使用 /g 和 /i标志位 令很多 JavaScript 初学者意外的是,字符串的 replace 方法并不会 替换所有匹配的子串—— ...

  2. JavaScript 开发者经常忽略或误用的七个基础知识点(转)

    JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它.昨天我们将这些模式应用到了 JavaScript 框架中,今天这些框架又驱动了我们的 Web 应用程序.很多新 ...

  3. JavaScript 开发者经常忽略或误用的七个基础知识点

    JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它.昨天我们将这些模式应用到了 JavaScript 框架中,今天这些框架又驱动了我们的 Web 应用程序.很多新 ...

  4. JavaScript开发者常忽略或误用的七个基础知识点

    JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它.昨天我们将这些模式应用到了 JavaScript 框架中,今天这些框架又驱动了我们的 Web 应用程序.很多新 ...

  5. (转)JavaScript 开发者经常忽略或误用的七个基础知识点

    英文原文:7 JavaScript Basics Many Developers Aren't Using (Properly) JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和 ...

  6. 第一百一十三节,JavaScript文档对象,DOM基础

    JavaScript文档对象,DOM基础 学习要点: 1.DOM介绍 2.查找元素 3.DOM节点 4.节点操作 DOM(Document Object Model)即文档对象模型,针对HTML和XM ...

  7. 什么是JavaScript闭包终极全解之一——基础概念

    本文转自:http://www.cnblogs.com/richaaaard/p/4755021.html 什么是JavaScript闭包终极全解之一——基础概念 “闭包是JavaScript的一大谜 ...

  8. JavaScript语言基础知识点图示(转)

    一位牛人归纳的JavaScript 语言基础知识点图示. 1.JavaScript 数据类型 2.JavaScript 变量 3.Javascript 运算符 4.JavaScript 数组 5.Ja ...

  9. JavaScript 语言基础知识点总结

    网上找到的一份JavaScript 语言基础知识点总结,还不错,挺全面的. (来自:http://t.cn/zjbXMmi @刘巍峰 分享 )  

随机推荐

  1. SSH:Struts2.2+Hibernate3.6+Spring3.1分页示例[转]

    参考资料 1 ssh分页(多个例子) http://useryouyou.iteye.com/blog/593954 2 ssh2分页例子 http://459104018-qq-com.iteye. ...

  2. hadoop 2.6配置记录

    本地hadoop配置 1)core-site.xml <?xml version="1.0" encoding="UTF-8"?> <?xml ...

  3. 使用php-cs-fixer格式化你的代码

    在开发中,我们会有意识的遵行一套规范来保证团队代码的一致性.PSR是我们PHP遵循的共同规范. 在这里,推荐一个代码格式化工具php-cs-fixer,可以一键把代码格式化为PSR-2的标准. 安装: ...

  4. NSOperation的start与main,并发与非并发。

    http://blog.csdn.net/a2331046/article/details/52294006 在ios4以前,只有非并发的情况下,队列会为operation开启一个线程来执行.如果是并 ...

  5. Bootstrap<基础十七>导航栏

    导航栏是一个很好的功能,是 Bootstrap 网站的一个突出特点.导航栏在您的应用或网站中作为导航页头的响应式基础组件.导航栏在移动设备的视图中是折叠的,随着可用视口宽度的增加,导航栏也会水平展开. ...

  6. 翻转和翻页效果TextFile的几种自定义例子

    前一篇文章,已经介绍了BMR的基础用法,再结合Spark和Scala的文档,我想应该是可以开始你的数据分析之路的.这一篇文章,着重进行一些简单的思路上的引导和分析.如果你分析招聘数据时,卡在了某个环节 ...

  7. Const(常量)与readonly(只读)的区别

    const与readonly定义的值都不能更改,但它们到底有哪些异同点呢? Const ² Const是常量的意思,其定义的变量只能读取不能更改,且只能在定义时初始化,不能在构造函数与其它属性与方法中 ...

  8. #1000 A + B (hihoCoder)

    时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 求两个整数A+B的和 输入 输入包含多组数据.每组数据包含两个整数A(1 ≤ A ≤ 100)和B(1 ≤ A ≤ 100) ...

  9. CentOS 静态IP设置

    一.CentOS 修改IP地址修改对应网卡的IP地址的配置文件 # vi /etc/sysconfig/network-scripts/ifcfg-eth0   电信 # vi /etc/syscon ...

  10. MFC-01-Chapter01:Hello,MFC---1.3 第一个MFC程序(04)

    1.3.3 框架窗口对象 MFC的CWnd类及其派生类为窗口或应用程序创建的窗口提供了面向对象的接口. CMainWindow是从CFrameWnd类派生而来,CFrameWnd模仿框架窗口的行为,可 ...