《JavaScript高级程序设计》 - 读书笔记 - 第5章 引用类型
5.1 Object 类型
对象是引用类型的实例。引用类型是一种数据结构,用于将数据和功能组织在一起。
新对象是使用new操作符后跟一个构造函数来创建的。构造函数本身就是一个函数,只不过该函数是出于创建新对象的目的而定义的。
示例1:
var person = new Object();
分析:这行代码创建了Object引用类型的一个新实例,然后把该实例保存在了变量person中。使用的构造函数是Object,它为新对象定义了默认的属性和方法。
Object类型是ECMAScript中使用最多的类型。对于在应用程序中存储和传输数据而言,它确实是非常理想的选择。
创建Object实例有两种方法,一个是new Object()的方法,另一种是使用对象字面值表示法。
示例2:使用对象字面值来创建person对象
var person = {
name : "Nicholas",
age : 29
};
使用对象字面值的好处在于简化创建包含大量属性的对象的过程。
在使用对象字面值时,属性名也可以使用字符串。
示例3:
var person = {
"name" : "Nicholas",
"age" : 29,
5 : true
};
分析:person对象包含三个属性:name、age和5。数值属性名会自动转换为字符串。
在使用对象字面值时,如果花括号内为空,则可以定义只包含默认属性和方法的对象。
示例4:
var person = {}; // 与 new Object()相同
开发人员更青睐于使用对象字面值来创建对象,因为这种语法要求的代码量少,而且能够给人封装数据的感觉。
实际上,对象字面值也是向函数传递大量参数的首选方式。
示例5:向函数传递参数
function displayInfo(args){
var output = "";
if(typeof args.name == "string"){
output += "Name: " + args.name + "\n";
}
if(typeof args.age == "number"){
output += "Age: " + args.age + "\n";
}
}
displayInfo({
name: "Nicholas",
age : 29
});
displayInfo({name : 29});
分析:函数接受一个名为args的参数。这个参数可能带有一个名为name或age的属性,也可能两个属性都有或者都没有。这里调用了两次函数,每次都是用对象字面值来指定不同的数据。虽然两次调用传递的参数不同,但函数都能正常工作。
一般来说,命名参数虽然容易处理,但在有多个可选参数的情况下就会显得不灵活。最好的做法是对那些必需值使用命名参数,而使用对象字面值来封装多个可选参数。
访问对象属性一般用点表示法,但在JavaScript中也可以使用方括号表示法。
在使用方括号表示法时,应该将要访问的属性以字符串的形式放在方括号中。
示例6:
alert(person["name"]);
alert(person.name);
从功能上看,这两种方式没有区别,但方括号语法的主要优点是可以通过变量来访问属性。
示例7:通过变量来访问对象属性
var myName = "name";
alert(person[myName]);
如果属性名中包括会导致语法错误的字符串,或者属性名为关键字,也可以使用方括号表示法。
示例8:
person["first name"] = "Nicholas";
分析:由于"first name"中包含一个空格,所以不能使用点表示法来访问它。
由于属性名中是可以包含非字母非数字的,这时就需要方括号表示法来访问它们。
通常,除非必须使用变量来访问属性,否则建议使用点表示法。
《JavaScript高级程序设计》 - 读书笔记 - 第5章 引用类型的更多相关文章
- Javascript高级程序设计读书笔记(第二章)
第二章 在HTML中使用Javascript 2.1<script>元素 延迟脚本(defer = "defer")表明脚本在执行时不会影响页面的构造,脚本会被延迟到 ...
- JavaScript高级程序设计学习笔记第五章--引用类型(函数部分)
四.Function类型: 1.函数定义的方法: 函数声明:function sum (num1, num2) {return num1 + num2;} 函数表达式:var sum = functi ...
- JavaScript高级程序设计学习笔记第五章--引用类型
一.object类型 1.创建object类型的两种方式: 第一种,使用构造函数 var person = new Object();或者是var person={};/与new Object()等价 ...
- javascript高级程序设计读书笔记
第2章 在html中使用javascript 一般都会把js引用文件放在</body>前面,而不是放在<head>里, 目的是最后读取js文件以提高网页载入速度. 引用js文 ...
- javascript高级程序设计读书笔记-事件(一)
读书笔记,写的很乱 事件处理程序 事件处理程序分为三种: 1.html事件2. DOM0级,3,DOM2级别 没有DOM1 同样的事件 DOM0会顶掉html事件 因为他们都是属性 而 ...
- JavaScript高级程序设计 读书笔记
第一章 JavaScript 简介 第二章 Html中使用JavaScript 第三章 基本概念 第四章 变量,作用域,内存 第五章 引用类型 第六章 面向对象 第七章 函数表达式 第八章 BOM 第 ...
- JavaScript高级程序设计-读书笔记(1)
第1章 JavaScript简介 JavaScript是一种专为与网页交互而设计的脚本语言,由下列三个不同的部分组成: l ECMAScript:提供核心语言功能: l 文 ...
- javascript高级程序设计 读书笔记2
第五章 引用类型 对象是引用类型的实例,引用类型是一种数据结构,将数据和功能组织在一起.描述的是一类对象所具有的属性和方法.对象是某个特定引用类型的实例,新对象是使用new操作符后跟一个构造函数俩创建 ...
- Javascript高级程序设计读书笔记(第六章)
第6章 面向对象的程序设计 6.2 创建对象 创建某个类的实例,必须使用new操作符调用构造函数会经历以下四个步骤: 创建一个新对象: 将构造函数的作用域赋给新对象: 执行构造函数中的代码: 返回新 ...
- JavaScript高级程序设计 读书笔记 第一章
JavaScript是一种专门为与网页交互而设计的脚本语言 JavaScript实现 ECMAscript---核心 DOM---文档对象模型 BOM---浏览器对象模型
随机推荐
- 给DB数据表加强制索引
DB2 数据库会根据DB层的统计值决定 根据查询条件走哪一个索引,某些情况下,由于未知原因,索引会走偏,故程序中可以规定程序走哪一个索引来避免索引走偏的情况发生. 强制走索引的 实例代码如下: SEL ...
- iOS之App加急审核详细步骤
申请加急网址:https://developer.apple.com/appstore/contact/appreviewteam/index.html 补充:加急审核说明是可以写中文的 提交加急审核 ...
- nodejs的child_process同步异步
nodejs是一种单线程模型,但是,使用nodejs的child_process模块可以实现多进程任务.利用child_process可以创建子进程,实现子进程和主进程之间的通信. nodejs v0 ...
- 字典转模型框架 Mantle的使用:国外程序员最常用的iOS模型
Mantle简介 Mantle 是iOS和Mac平台下基于Objective-C编写的一个简单高效的模型层框架. Mantle能做什么 Mantle可以轻松把JSON数据.字典(Dictionary) ...
- JAVA匿名内部类
首先定义一个抽象类Computer public abstract class Computer { //抽象类是不可以常见对象的 int a=1; public abstract void onli ...
- 【代码笔记】iOS-替换电话号码中间4位为-号
一,效果图. 二,代码. RootViewController.m - (void)viewDidLoad { [super viewDidLoad]; // Do any additional se ...
- (转)[原] Android 自定义View 密码框 例子
遵从准则 暴露您view中所有影响可见外观的属性或者行为. 通过XML添加和设置样式 通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器 详细步骤见:Android 自定义View步骤 ...
- IOS网络请求的一些需要记录的info设置
info.plist文件: <key>NSExceptionDomains</key> <dict> <key>appapi.700bike.com&l ...
- Java和WebSocket开发网页聊天室
小编心语:咳咳咳,今天又是聊天室,到现在为止小编已经分享了不下两个了,这一次跟之前的又不大相同,这一次是网页聊天室,具体怎么着,还请各位看官往下看~ Java和WebSocket开发网页聊天室 一.项 ...
- Linux sendmail发送邮件失败诊断案例(一)
在新服务器上测试sendmail发送邮件时,发现邮件发送不成功,检查日志文件发现如下错误(Notice:由于涉及公司服务器,邮箱等,故下面hostname.邮箱地址等信息使用xxx代替) tail - ...