《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---浏览器对象模型
随机推荐
- AndroidTV版(乐视超3 X55)root,将自己的软件设置为开机自启、系统软件,卸载系统应用等问题总结
最近开发android软件客户要安装在乐视TV上,而且要求是开机自启.我很天真的以为写一个广播接收类接收开机广播就可以了,可是根本不会,有的设备就是不可以接收到开机广播,于是各种百度搜索.大神们说是只 ...
- Maven之 聚合与继承 详解
说到聚合与继承我们都很熟悉,maven同样也具备这样的设计原则,下面我们来看一下Maven的pom如何进行聚合与继承的配置实现. 一.为什么要聚合? 随着技术的飞速发展和各类用户对软件的要求越来越高, ...
- Git 工作流程
Git 作为一个源码管理系统,不可避免涉及到多人协作. 协作必须有一个规范的工作流程,让大家有效地合作,使得项目井井有条地发展下去.”工作流程”在英语里,叫做”workflow”或者”flow”,原意 ...
- OracleHelper类
using System; using System.Collections; using System.Collections.Generic; using System.Data; using S ...
- SQL SERVER 2000通过链接服务器发送邮件出现错误
案例环境: 服务器A系统: Windows Server 2000 数据库版本 : Microsoft SQL Server 2000 - 8.00.2282 (Intel X86) 服务器B系统: ...
- winform(四)——简单计算器制作
效果图: 代码区: using System; using System.Collections.Generic; using System.ComponentModel; using System. ...
- 统计文件种类数+获取子shell返回值的其它方法
前言 只是作为一个shell的小小练习和日常统计用,瞎折腾的过程中也是摸到了获取子shell返回值的几种方法: 肯定还有别的方法,跟进程间的通信相关,希望你能提出建议和补充,谢谢~ 完整程序: #! ...
- silicon labs 代理商
http://www.silabs.com/buysample/pages/contact-sales.aspx?SearchLocation=China Silicon Labs A ...
- [django]Django站点admin支持中文显示和输入设置
正文: Django站点admin支持中文输入设置,操作如下: 1 需要确定的你的数据库的client客户端和服务端的编码设置为utf-8,如果不是,请将其设置成utf-8编码,我采用mysql,详情 ...
- 《InsideUE4》UObject(一)开篇
UE生UObject,UObject生万物 引言 在上个GamePlay专题,谈到UE创建游戏世界的时候(GamePlay架构(一)Actor和Component),简单的介绍了一下UObject的功 ...