《JavaScript应用程序设计》一一第3章 对象

简介:

第3章

对象
JavaScript拥有原型继承、动态对象扩展、闭包等特性,在现今市面上流行的所有编程语言中,基于对象编程的JavaScript最具灵活性与表现力。
在JavaScript中,你可以将诸如函数、数组、键/值对以及一些基础数据结构都视为对象,甚至一些原始数据类型在用点语法做属性操作时,也会被JavaScript隐式当作对象处理。为了能够调用原型链上的方法,原始数据类型在使用时会被临时包裹为对象,例如:
'tonya@example.com'.split('@')[1]; // => example.com
警告: 当你使用点语法操作原始数据类型的属性时,会使得原始数据类型看起来更像是一个对象,其实它只是在短时间内被JavaScript引擎临时包裹为对象而已。你无法像对待真正的对象那样为原始数据类型添加新的属性,即使属性看起来像是被添加“成功”了,实则却不能够被访问。
JavaScript语言所构建的对象系统是如此灵活强大,以至于大多数面向对象的编码模式在JavaScript中都被简化,特别是在某些轻量级的任务中,完全用不着动用这些笨重的家伙们。例如,JavaScript中是没有类概念的,在其他语言中你需要依靠“惰性实例化”这一设计模式来实现按需构建对象, 而在JavaScript中,仅仅使用对象字面量就够了。

var highlander = {
    name: 'McLeod',
    catchphrase: 'There can be only one.'
  };

在阅读本章的过程中,你会发现当你真正了解并掌握了JavaScript中原生对象的强大特性时,大多数设计模式丛书(http://bit.ly/1pwzcUc)中介绍的编码模式都可以被抛在脑后。
JavaScript并不是一门面向对象的语言,确切地来说它是一门原型语言,然而市面上大多数JavaScript教程对类语言与原型语言间的差异性并没有做详细的介绍。为了让JavaScript代码更具执行效率与可读性,你需要对原型编程的理念做足够的掌握,不过在这之前,我们先简单了解下传统类继承的一些弊病。

相关文章
|
3天前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
17 3
|
16天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
26天前
|
JavaScript 前端开发
Math对象:JavaScript中的数学工具
Math对象:JavaScript中的数学工具
27 1
N..
|
1月前
|
存储 JavaScript 前端开发
JavaScript中的对象
JavaScript中的对象
N..
10 0
|
1月前
|
JavaScript 前端开发
JavaScript对象系列(菜菜出品,必看!!!)
JavaScript对象系列(菜菜出品,必看!!!)
|
2月前
|
JavaScript 前端开发
JS将两个数组和合并成数组包对象格式的方法
JS将两个数组和合并成数组包对象格式的方法
28 0
|
19天前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
1月前
|
存储 JavaScript 前端开发
在JavaScript中,对象和数组是如何进行扩展的?
在JavaScript中,对象和数组是如何进行扩展的?
22 4
|
5天前
|
JavaScript 前端开发 开发者
JavaScript中的错误处理:try-catch语句与错误对象
【4月更文挑战第22天】JavaScript中的错误处理通过try-catch语句和错误对象实现。try块包含可能抛出异常的代码,catch块捕获并处理错误,finally块则无论是否出错都会执行。错误对象提供关于错误的详细信息,如类型、消息和堆栈。常见的错误类型包括RangeError、ReferenceError等。最佳实践包括及时捕获错误、提供有用信息、不忽略错误、利用堆栈信息和避免在finally块中抛错。
|
11天前
|
JavaScript
【Js】检查Date对象是否为Invalid Date
【Js】检查Date对象是否为Invalid Date
14 0