对象的类型:本地对象(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 相关文章推荐
multiSteps 基于Jquery的多步骤滑动切换插件
Jul 22 Javascript
使用jQuery内容过滤选择器选择元素实例讲解
Apr 18 Javascript
jQuery中ajax的使用与缓存问题的解决方法
Dec 19 Javascript
JQuery 在线引用及测试引用是否成功
Jun 24 Javascript
jQuery图片轮播滚动切换代码分享
Apr 20 Javascript
jQuery实现分隔条左右拖动功能
Nov 21 Javascript
jQuery实现图片上传和裁剪插件Croppie
Nov 29 Javascript
jQuery表单元素过滤选择器用法实例分析
Feb 20 jQuery
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
May 17 Javascript
vue路由插件之vue-route
Jun 13 Javascript
原生JS 实现的input输入时表格过滤操作示例
Aug 03 Javascript
VUE解决 v-html不能触发点击事件的问题
Oct 28 Javascript
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
Zend Studio 无法启动的问题解决方法
2008/12/04 PHP
PHP连接MongoDB示例代码
2012/09/06 PHP
PHP_NETWORK_GETADDRESSES: GETADDRINFO FAILED问题解决办法
2014/05/04 PHP
Laravel框架中VerifyCsrfToken报错问题的解决
2017/08/30 PHP
Linux下 php7安装redis的方法
2018/11/01 PHP
用js实现预览待上传的本地图片
2007/03/15 Javascript
jQuery选择器的工作原理和优化分析
2011/07/25 Javascript
javascript框架设计读书笔记之模块加载系统
2014/12/02 Javascript
Js实现自定义右键行为
2015/03/26 Javascript
text-align:justify实现文本两端对齐 兼容IE
2015/08/19 Javascript
Node.js中JavaScript操作MySQL的常用方法整理
2016/03/01 Javascript
JS+HTML5实现的前端购物车功能插件实例【附demo源码下载】
2016/10/17 Javascript
Vue内容分发slot(全面解析)
2017/08/19 Javascript
JavaScript设计模式之观察者模式(发布订阅模式)原理与实现方法示例
2018/07/27 Javascript
jQuery 实现倒计时天,时,分,秒功能
2018/07/31 jQuery
支付宝小程序自定义弹窗dialog插件的实现代码
2018/11/30 Javascript
小程序封装wx.request请求并创建接口管理文件的实现
2019/04/29 Javascript
vue项目在线上服务器访问失败原因分析
2020/08/14 Javascript
JS PHP字符串截取函数实现原理解析
2020/08/29 Javascript
[01:07:19]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第一场 1月19日
2021/03/11 DOTA
Python多线程编程(八):使用Event实现线程间通信
2015/04/05 Python
Python画图学习入门教程
2016/07/01 Python
利用python程序帮大家清理windows垃圾
2017/01/15 Python
Django基础知识 web框架的本质详解
2019/07/18 Python
python字典的遍历3种方法详解
2019/08/10 Python
Python二元赋值实用技巧解析
2019/10/25 Python
使用TensorFlow直接获取处理MNIST数据方式
2020/02/10 Python
HTML5 localStorage使用总结
2017/02/22 HTML / CSS
全球最大的在线橄榄球商店:Lovell Rugby
2018/05/20 全球购物
澳大利亚当地社区首选的光学商店:1001 Optical
2019/08/24 全球购物
企业治理工作自我评价
2013/09/26 职场文书
诉讼代理人授权委托书
2014/04/08 职场文书
装配出错检讨书
2014/09/23 职场文书
本溪水洞导游词
2015/02/11 职场文书
异地恋情人节寄语
2015/02/28 职场文书
2015年小学语文工作总结
2015/05/25 职场文书