第4章 对象

4.1 从数组到对象

对象的组成:变量名、{}、用逗号分割的属性、用冒号分割的键/值对。

        var f={
name:'alen', // 可以在属性名上加引号
age:12
};

对象文本标识法:用{}定义对象的方法;数组文本标识法:用[]定义数组的方法。

4.1.1 元素、属性、方法与成员

数组包含元素,对象包含属性。说法不同,但本质相同。当对象的属性为函数时,称该属性为方法。

        var dog={
name:'aa',
talk:function (){ //talk是一个方法
alert('woof,woof!');
}
};

4.1.2 哈希表、关联型数组

数组形式:

一般性数组:也叫索引型数组或枚举型数组(通常以数字为键名)

关联型数组:哈希表或字典(通常以字符串为键值)

4.1.3 访问对象属性

中括号表示法:如dog['name'].

点号表示法:dog.name      可以混合使用两种表示法

如果要访问的属性名不确定,必须使用中括号表示法。

4.1.4 调用对象方法

在指定的方法名后面加()

dog.talk(); //或dog['talk']()

4.1.5 修改属性与方法

        //为对象添加属性和方法
var hero={};
hero.name='a';
hero.sayName=function (){
return hero.name;
};
//调用方法
hero.sayName();
//删除属性
delete hero.name

4.1.6 使用this值

       var hero={
name:'a',
sayName:function (){
return this.name; // this引用当前对象或这个对象
}
};

4.1.7 构造器函数

通过构造器函数来创建对象

       //使用构造器函数来创建对象,构造器函数的首字母一般大写
function Hero(){
this.name='a';
}
//使用new操作符,为该函数创建对象
var f1=new Hero();
f1.name; // "a"
//没用使用new操作符
var f1=Hero();
typeof h; // "undefined"

4.1.8 全局对象

当宿主的环境是web浏览器时,它提供的全局对象是window。

var a=1;
window.a;//
this.a; //1

当构造函数不使用new时,this指向全局对象,所以typeof h;// undefined

4.1.9 构造器属性

constructor property:指向用于创建该对象的构造器函数的引用。

 function Hero(){};
var a=new Hero();
a.constructor; // function Hero(){}
var o={}; // 由内建构造函数Object()创建
o.constructor; // function Object() { [native code] }

4.1.10 instanceof 操作符

测试一个对象是否为某一个指定的构造器函数所创建。

a instanceof Hero;  // true

4.1.11 返回对象的函数

使用一般函数来创建对象。

        function factory(name){
return {
name:name
};
}
var o=factory('one');
o.name; // "one"
o.constructor; // function Object() { [native code] }

4.1.12 传递对象

当拷贝某个对象或者将它传递给某个函数时,往往传递的是该对象的引用。因此在引用上所做的任何更改,都会影响它所引用的原对象。

        var f1={age:};
var f2=f1;
f1.age; //
f2.age=; //改变age的值
f1.age; // 100 f1中age的值也发生改变

4.1.13 比较对象

对象比较操作时,当且仅当两个引用指向同一个对象,结果为true。

        var f3={name:"alen"};
var f4={name:"alen"};
f3===f4; // false

4.2 内建对象

内建对象大致分为三类:

数据封装类对象——包括Object、Array、Boolen、String、Number。

工具类对象——Nath、Date、RegExp等

错误类对象

4.2.3 Function

三种定义函数的方式

        // 函数定义的三种方式

         // 函数声明
function sum(a,b){
return a+b;
}
// 函数表达式
var sum=function (a,b){
return a+b;
}
// 构造函数 不推荐使用
var sum=new Function('a','b','return a+b');
4.2.3.1 函数对象的属性

constructor:引用Function这个构造器函数

length:参数的数量

        function f1(){
return ;
};
f1.constructor; // function Function() { [native code] }

prototype属性:指向一个对象,只有该函数是构造器时才会发挥作用。

4.2.3.2 函数对象的方法

拥用Object对象的方法。toString()方法:函数的源代码

        function f1(){
return ;
};
f1.constructor; // function Function() { [native code] }
f1.toString(); // "function f1(){return 1;}" 源代码
parseInt.toString(); // "function parseInt() { [native code] }" 内建函数
// 可以使用toString来区分本地方法和自定义方法
4.2.3.3 call()与apply()

每个函数都有call()和apply()方法,用来触发函数并指定相应的参数。

可是实现代码重用:让一个对象去借用另一个对象的方法。

       var f1={
name:'Alen',
say:function (who){
return 'Hi '+who+', I am '+this.name;
}
};
f1.say('XiaoMing'); //"Hi XiaoMing, I am Alen"
var f2={name:'XiaoLi'};
// f2调用f1的say()方法 f1的say方法借给f2
f1.say.call(f2,'XiaoMing'); //"Hi XiaoMing, I am XiaoLi"
// apply方法参数的传递通过数组
f1.say.apply(f2, ['XiaoMing']); //"Hi XiaoMing, I am XiaoLi"
4.2.3.4 重新认识arguments对象

arguments和数组相比只包含了索引元素和length属性。但可以把arguments转换为数组,从而使用各种数组的方法。

        function f(){
var args=Array.prototype.slice.call(arguments);//继承数组的方法
// var args=[].slice.call(arguments);
return args.reverse(); //翻转
}
f(,,,); // [4, 3, 2, 1]

JavaScript面向对象编程指南(四) 对象的更多相关文章

  1. 「JavaScript面向对象编程指南」对象

    对象的属性名可加上引号,下面三行代码所定义的内容是完全相同的 var hero = { occupation : 1 }; var hero = { "occupation" : ...

  2. 《JavaScript面向对象编程指南(第2版)》读书笔记(一)

    目录 一.对象 1.1 获取属性值的方式 1.2 获取动态生成的属性的值 二.数组 2.1 检测是否为数组 2.2 增加数组长度导致未赋值的位置为undefined 2.3 用闭包实现简易迭代器 三. ...

  3. 《JavaScript面向对象编程指南(第2版)》读书笔记(二)

    <JavaScript面向对象编程指南(第2版)>读书笔记(一) <JavaScript面向对象编程指南(第2版)>读书笔记(二) 目录 一.基本类型 1.1 字符串 1.2 ...

  4. 《JavaScript面向对象编程指南》读书笔记②

    概述 <JavaScript面向对象编程指南>读书笔记① 这里只记录一下我看JavaScript面向对象编程指南记录下的一些东西.那些简单的知识我没有记录,我只记录几个容易遗漏的或者精彩的 ...

  5. 《JavaScript面向对象编程指南》读书笔记①

    概述 JavaScript快忘完了,想看一本专业书拾遗,所以看了这本<JavaScript面向对象编程指南>. 个人觉得这本书讲的很透彻很易懂,一些原来有疑惑的地方在这本书里面豁然开朗,看 ...

  6. 闭包初体验 -《JavaScript面向对象编程指南》

    下面是我对闭包的理解:(把他们整理出来,整理的过程也是在梳理) 参考<JavaScript面向对象编程指南> 1.首先,在理解闭包之前: 我们首先应该清楚下作用域和作用域链 作用域:每个函 ...

  7. js_读【javascript面向对象编程指南】笔记

    写在前面: 工欲善其事,必先利其器.编程的器,是前人总结的经验,常言道站在巨人的肩膀上开发,往往比自己另辟蹊径容易的多.经验藏于书,故有书中自有颜如玉,书中自有黄金屋,我也一度认为读书要花费很多时间, ...

  8. 《JavaScript面向对象编程指南》

    第一章.引言 1.5 面向对象的程序设计常用概念 对象(名词):是指"事物"在程序设计语言中的表现形式. 这里的事物可以是任何东西,我们可以看到它们具有某些明确特征,能执行某些动作 ...

  9. 《JavaScript面向对象编程指南》译者序

    相对于Perl.Python等动态脚本语言来说,JavaScript确实是一门饱受误解的语言.对于译者这种从20世纪90年代末走过来的C++程序员来说,尤其如此.在那个年代,提起JavaScript总 ...

随机推荐

  1. Spring MVC之中前端向后端传数据

    Spring MVC之中前端向后端传数据和后端向前端传数据是数据流动的两个方向, 在此先介绍前端向后端传数据的情况. 一般而言, 前端向后端传数据的场景, 大多是出现了表单的提交,form表单的内容在 ...

  2. 神奇的CSS3混合模式

    神奇的css3混合模式 对于前端开发人员应该都很熟悉Photoshop的图层混合模式,就是几个图层按不同的模式进行混合,实现不同的图像效果.但是当我们前端同学在切这些效果图的时候,基本上就是一刀切的, ...

  3. python之连接oracle模块(cx_Oracle)

    cx_Oracle模块下载地址如下: https://pypi.python.org/pypi/cx_Oracle/5.2.1#downloads 安装好之后就可以使用了,具体使用如下 #!/usr/ ...

  4. java提高(7)---TreeSet--排序

    TreeSet(一) 一.TreeSet定义:      与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.            1)TreeSet类概述 ...

  5. 整理一下pywinauto 的sendeys(py2.7)换成python3.6用PyUserInput

    没办法入门学的是py3.6所以有些只支持2.7的库保好放弃了 senkeys (2.7)==>pyuserinput (3.6) ================================ ...

  6. 【Objective-C】内存管理

    涉及三大知识点:引用计数器,属性参数,自动释放池 一.引用计数器(程序编译时Xcode可以自动给你的代码添加内存释放代码,如果编写手动释放代码Xcode会报错) 1.关闭ARC(xcode 4.x之后 ...

  7. 《JavaScript总结》深拷贝和浅拷贝

    在javascript中,数据主要分基本类型和引用类型两种. 基本类型的赋值比较简单,但是引用类型的赋值,会存在一些问题,那我们用代码来分析一下. 一.浅拷贝 var one = "测试1& ...

  8. 支付宝PC端单笔支付同步回调session失效问题

    一次调用支付宝PC场景下单笔支付之后同步回调遇到的session失效问题记录 问题描述: 调用支付宝接口:alipay.trade.page.pay,该接口请求参数中有两个返回地址需要设置,retur ...

  9. 权限控制和OAuth

    目录 1 权限控制是什么 1.1 ACL 1.2 RBAC 1.2.1 名词术语 1.2.2 RBAC定义 1.2.3 RBAC分类 1.2.3.1 RBAC0 1.2.3.2 RBAC1 1.2.3 ...

  10. NET Core微服务之路:弹性和瞬态故障处理库Polly的介绍

    前言 上一节中我们介绍了Ocelot的常见使用配置,通过json配置文件,实现API网关的请求处理.和一个使用DownStream扩展下游中间件,来实现Http转RPC的简单实现,功能不算强大,但可以 ...