对象的类型:本地对象(1)


Posted in Javascript onDecember 29, 2006
在ECMAScript中,所有对象并非同等创建的。一般说来,可以创建并使用的对象有三种。

3.3.1 本地对象

ECMA-262把本地对象(native object)定义为“独立于宿主环境的ECMAScript实现提供的对象”。简单说来,本地对象就是ECMA-262定义的类(引用类型)。它们包括:
对象的类型:本地对象(1)
你已经从上一章了解了一些本地对象(Object、Function、String、Boolean和Number),本书后面的章节中还会讨论一些本地对象。现在要讨论的两种重要的本地对象是Array和Date。
1. Array
与Java不同的是,在ECMAScript中有真正的Array类。可以如下创建Array对象:
对象的类型:本地对象(1)
如果预先知道数组中项的个数,可以用参数传递数组的大小:
对象的类型:本地对象(1)
使用这两个方法,一点要使用括号,与它们在Java中的用法相似:
对象的类型:本地对象(1)
这里创建了一个数组,并定义了三个数组项,即"red"、"green"和"blue"。每增加一个数组项,数组的大小就动态地增长。
此外,如果知道数组应该存放的值,还可用参数声明这些值,创建大小与参数个数相等的Array对象。例如,下面的代码将创建一个有三个字符串的数组:
对象的类型:本地对象(1)
与字符串类似,数组中的第一个项位于位置0,第二个项位于位置1,依此类推。可通过使用方括号中放置要读取的项的位置来访问特定的项。例如,要用刚才定义的数组输出字符串"green",可以采用下面的代码:
对象的类型:本地对象(1)
可用属性length得到数组的大小。与字符串的length属性一样,数组的length属性也是最后一个项的位置加1,意味着具有三个项的数组中的项的位置是从0到2。
对象的类型:本地对象(1)
前面提过,数组可以根据需要增大或减小。因此,如果要为前面定义的数组增加一项,只需把要存放的值放入下一个未使用的位置即可:
对象的类型:本地对象(1)
在这段代码中,下一个未使用的位置是3,所以值"purple"将被赋予它。增加一项使数组的大小从3变成了4。但如果把值放在这个数组的位置25处会怎样呢?ECMAScript将把从3开始到24的所有位置都填上值null,然后在位置25处放上正确的值,并把数组大小增大为26:
对象的类型:本地对象(1)
数组最多可以存放4294967295项,这应该可满足大多数程序设计的需要。如果要添加更多的项,则会发生异常。
还可以用字面量表示定义Array对象,即使用方括号([和]),用逗号分隔值。例如,可以用下面的形式重写前面的例子:
对象的类型:本地对象(1)
注意,在这个例子中,未明确使用Array类。方括号暗示把其中的值存放在Array对象中。用这种方式声明的数组与用传统方式声明的数组相同。
Array对象覆盖了toString()方法和valueOf()方法,返回特殊的字符串。该字符串是通过对每项调用toString()方法,然后用逗号把它们连接在一起构成的。例如,对具有项"red"、"green"和"blue"的数组调用toString()方法或valueOf()方法,返回的是字符串"red,green,blue"。
对象的类型:本地对象(1)
类似的,toLocaleString()方法返回的也是由数组项构成的字符串。唯一的区别是得到的值是通过调用每个数组项的toLocaleString()方法得到的。许多情况下,该方法返回的值都与toString()方法返回的值相同,也是用逗号连接字符串。
对象的类型:本地对象(1)
由于开发者也可能希望在数组之外创建这样的值,所以ECMAScript提供了方法join(),它唯一的用途就是连接字符串值。join()方法只有一个参数,即数组项之间使用的字符串。考虑下面的例子:
对象的类型:本地对象(1)
这里用方法join()创建了三种不同的数组表示。第一个join()方法使用逗号,本质上与调用toString()方法或valueOf()方法等价。第二个和第三个join()方法使用不同的字符串,在数组项之间创建了奇怪的分隔符(可能不怎么有用)。理解的重点在于任何字符串都可以用作分隔符。
此刻也许你想知道,既然Array具有把自己转换成字符串的方法,那么String是否有把自己转换成数组的方法呢?答案是肯定的。String类的方法split()正用于此。split()方法只有一个参数。可能有读者已经猜到,该参数就是被看作数组项之间的分隔符的字符串。因此,如果有一个由逗号分隔的字符串,就可以用下面的代码把它转换成Array对象:
对象的类型:本地对象(1)
如果把空字符串声明为分隔符,那么split()方法返回的数组中的每个项是字符串的字符,例如:
对象的类型:本地对象(1)
这里,字符串"green"将被转换成字符串数组"g"、"r"、"e"、"e"和"n"。如果需要逐个字符的解析字符串,这种功能非常有用。
Array对象具有两个String类具有的方法,即concat()和slice()方法。concat()方法处理数组的方式几乎与它处理字符串的方式完全一样。参数将被附加在数组末尾,返回的函数值是新的Array对象(包括原始数组中的项和新的项)。例如:
对象的类型:本地对象(1)
在这个例子中,用concat()方法把字符串"yellow"和"purple"加到数组中。数组aColors2包括5个值,而原始数组aColors仍只有3个值。可通过对两个数组分别调用toString()方法证明这一点。
Javascript 相关文章推荐
六款帮助你实现惊艳视差滚动效果的jQuery插件
Sep 14 Javascript
javaScript使用EL表达式的几种方式
May 27 Javascript
Node.js开发之访问Redis数据库教程
Jan 14 Javascript
数据分析软件之FineReport教程:[5]参数界面JS(全)
Aug 13 Javascript
jQuery实现侧浮窗与中浮窗切换效果的方法
Sep 05 Javascript
Bootstrap文件上传组件之bootstrap fileinput
Nov 25 Javascript
jquery Easyui Datagrid实现批量操作(编辑,删除,添加)
Feb 20 Javascript
微信小程序用户自定义模版用法实例分析
Nov 28 Javascript
vue二级路由设置方法
Feb 09 Javascript
vue实现裁切图片同时实现放大、缩小、旋转功能
Mar 02 Javascript
详解webpack 打包文件体积过大解决方案(code splitting)
Apr 10 Javascript
jQuery实现基本淡入淡出效果的方法详解
Sep 05 jQuery
JavaScript高级程序设计
Dec 29 #Javascript
JavaScript 参考教程
Dec 29 #Javascript
js自带函数备忘 数组
Dec 29 #Javascript
slice函数的用法 之不错的应用
Dec 29 #Javascript
通过js脚本复制网页上的一个表格的不错实现方法
Dec 29 #Javascript
javascript中对对层的控制
Dec 29 #Javascript
JavaScript方法和技巧大全
Dec 27 #Javascript
You might like
php PDO中文乱码解决办法
2009/07/20 PHP
ThinkPHP使用getlist方法实现数据搜索功能示例
2017/05/08 PHP
php微信公众号开发之快递查询
2018/10/20 PHP
编写兼容IE和FireFox的脚本
2009/05/18 Javascript
js setTimeout 常见问题小结
2013/08/13 Javascript
Firefox和IE兼容性问题及解决方法总结
2013/10/08 Javascript
Extjs改变树节点的勾选状态点击按钮将复选框去掉
2013/11/14 Javascript
Jquery之Bind方法参数传递与接收的三种方法
2014/06/24 Javascript
JS+CSS实现带小三角指引的滑动门效果
2015/09/22 Javascript
Jqprint实现页面打印
2017/01/06 Javascript
JS中如何实现点击a标签返回页面顶部的问题
2017/01/19 Javascript
Bootstrap响应式表格详解
2017/05/23 Javascript
vue结合axios与后端进行ajax交互的方法
2018/07/06 Javascript
JS简单数组排序操作示例【sort方法】
2019/05/17 Javascript
Vue中axios的封装(报错、鉴权、跳转、拦截、提示)
2019/08/20 Javascript
ES6基础之 Promise 对象用法实例详解
2019/08/22 Javascript
JavaScript写个贪吃蛇小游戏(超详细)
2020/03/17 Javascript
[10:49]2014国际邀请赛 叨叨刀塔第二期为真正的电竞喝彩
2014/07/21 DOTA
Python中pip安装非PyPI官网第三方库的方法
2015/06/02 Python
Python实现自动登录百度空间的方法
2017/06/10 Python
python学习——内置函数、数据结构、标准库的技巧(推荐)
2019/04/18 Python
Python Opencv实现图像轮廓识别功能
2020/03/23 Python
python 求10个数的平均数实例
2019/12/16 Python
python 基于Apscheduler实现定时任务
2020/12/15 Python
CSS3之多背景background使用示例
2013/10/18 HTML / CSS
CSS去掉A标签(链接)虚线框的方法
2014/04/01 HTML / CSS
CSS3与动画有关的属性transition、animation、transform对比(史上最全版)
2017/08/18 HTML / CSS
中国排名第一的外贸销售网站:LightInTheBox.com(兰亭集势)
2016/10/28 全球购物
应届生求职自荐信范文
2014/04/07 职场文书
销售个人求职信范文
2014/04/28 职场文书
乡镇安全生产目标责任书
2014/07/23 职场文书
声乐专业大学生职业生涯规划书:理想的未来需要自己去打造
2014/09/20 职场文书
学生评语集锦
2015/01/04 职场文书
2015年安全生产月工作总结
2015/07/27 职场文书
Redis调用Lua脚本及使用场景快速掌握
2022/03/16 Redis
戴尔Win11系统no bootable devices found解决教程
2022/09/23 数码科技