JavaScript1.6数组新特性和JQuery的几个工具方法

JavaScript 1.6 引入了几个新的Array 方法,具体的介绍见:New in JavaScript 1.6 。这些方法已经被写进了ECMA262 V5。现代浏览器(IE9/Firefox/Safari/Chrome/Opera)都已经支持,但IE6/7/8不支持。jquery的工具方法中提供了类似的功能。

数组Array在JavaScript中是一个非常强大的对象,而在JavaScript1.6中,Array则成为该版本更新的重头戏,下面,我们来看一下W3C Group给我们带来的关于JavaScript1.6的新特性描述!
JavaScript1.6带来了以下一些新的特性,包括:E4X(ECMAScript for XML),新的Array方法,及数组和字符串泛型。E4X

ECMAScript for XML (E4X) 是用于创建和处理JavaScript正文中的XML内容的强大工具。我们将继续改进对E4X的支持,包括增加与现有DOM的透明整合,但创建基于XML 之Web应用程序的开发人员已经可以从Firefox 1.5对E4X的支持中获益。

您在使用E4X的同时仍旧可以使用标准MIME类型:

<script type="text/javascript">

不过,按照E4X语法书写的代码可能与现有的为兼容不支持JavaScript浏览器而加入的HTML注释(<!--...-->)冲突,甚至,与近年来更为流行的XML CDATA段落标记(<![CDATA[...]]>)也可能冲突,不兼容 ,XML CDATA是为了容许"<" 与 ">"出现在脚本中,(这并不符合HTML规范)。若您读到无法解释或异常出现的语法错误,可以尝试向script标记的MIME type类型属性中添加"; e4x=1":

<script type="text/javascript; e4x=1">

注意扩展的脚本总是将HTML注释视为E4X合法字符,也就是说,"e4x=1"属性是默认的。

数组扩展

七个新的Array方法可以分成两类:项(item)的定位方法和迭代方法。 项定位方法为:

    * indexOf() - 返回指定项首次出现的索引。
    * lastIndexOf() - 返回指定项最后一次出现的索引。

迭代方法包括:

    * every() - 在数组中的每个项上运行一个函数,若所有结果都返回真值,此方法亦返回真值。
    * filter() - 在数组中的每个项上运行一个函数,并将函数返回真值的项作为数组返回。
    * forEach() - 在数组中的每个项上运行一个函数。
    * map() - 在数组中的每个项上运行一个函数,并将全部结果作为数组返回。
    * some() - 在数组中的每个项上运行一个函数,若存在任意的结果返回真,则返回真值。

数组及字符串泛型

您有时也许会想在字符串类型上使用数组拥有的方法。这样做的话,您实际上将字符串视如一个字符数组。例如,想要检查变量str中是否每个字符都是字母,您可以这样写:

function isLetter(character) {
return (character >= "a" && character <= "z");
}
if (Array.prototype.every.call(str, isLetter))
alert("The string '" + str + "' contains only letters!");

这种写法有点浪费,故JavaScript 1.6引入了泛型的简洁写法:

if (Array.every(str, isLetter))
alert("The string '" + str + "' contains only letters!");
类似地,您可以简单地将对任何对象应用字符串方法:
var num = 15;
alert(String.replace(num, /5/, '2'));
相信大家对javascript1.6的这些新特性一定有些心动了,W3C Group将继续为大家带来javascript1.7的新特性介绍!

1、Array.forEach()和jquery的$().each()。在数组中的每个项上运行一个函数。类似java5 增强的for循环

var ary = [2,4,6,8];
 
// js1.6 Array.forEach方法
ary.forEach(function(i){alert(i);});
 
// jquery的写法
$(ary).each(function(){alert(this);});
//还可以写成这样
$(ary).each(function(index,item){alert(item);});//index是元素的索引,item是该元素

相关推荐