《javaScript高级程序设计》读书笔记(四)

以下内容可能存在个人理解的部分,并非完全参照原文

如有疑问,请以书中内容为准

接着上一篇的内容

3.6 语句

大部分和其他语言差不多

只需要注意ECMAScript没有块级作用域

var count = 10;
for(var i = 0; i < count; i++) {
    alert(i);
}
alert(i); // 10

{}声明的变量可以在外部访问到

3.7 函数

理解参数

ECMAScript函数的参数与大多数其他语言不同。

ECMAScript函数不介意传递进来多少个参数,也不在乎传进来的参数是什么数据类型。即便你定义的函数只接受两个参数,在调用时也未必一定要传递两个参数。

原因是ECMAScript中的参数在内部是用一个数组来表示的。函数接收到的始终都是这个数组,而不关心数组中包含哪些参数。

实际上,在函数体内可以通过arguments对象来访问这个参数数组,从而获取传递给函数的每一个参数。

arguments对象与数组类似(但不是Array的实例),可以使用[]来访问他的每一个元素,使用length属性来确定传递进来多少个参数。

可以这样

function doAdd() {
    if(arguments.length == 1) {
        alert(arguments[0] + 10);
    } else if (arguments.length == 2) {
        alert(arguments[0] + arguments[1]);
    }
}
doAdd(10);      // 20
doAdd(20,30);   // 50

关于arguments的行为,还有一点比较有意思。那就是它的值永远与对应命名参数的值保持同步。

但是如果那个命名参数没有传入值,使用arguments设置的值将不会反映到命名参数中

function doAdd(num1,num2){
    arguments[1] = 10;
    alert(arguments[0] + num2);
}
test(1)     // NaN -- 1 + undefined
test(1,2)   // 11

没有重载

定义两个同名函数,则该名字只属于后定义的函数。

第四章 变量、作用域和内存问题

JavaScript变量松散类型的本质,决定了它只是在特定事件用于保存特定值的一个名字而已。

4.1 基本类型和引用类型的值

基本类型值指的是简单的数据段,有UndefinedNullBooleanNumberString

引用类型值指那些可能由多个值构成的对象

JavaScript不允许直接访问内存中的位置

ECMAScipt中的字符串是以基本类型来表示的,而不是对象

动态的属性

我们只能给对象添加属性

var person = new Object();
person.name = "Nicholas";
alert(person.name);     // "Nicholas"

如果我们给基本类型添加属性,将不会起作用

var name = "Nicholas";
name.age = 27;      // 不会报错
alert(name.age);    // Undefined

复制变量值

如果从一个变量向另一个变量复制基本类型的值,会在变量对象上创建一个新值,然后把该值复制到为新变量分配的位置上。

var num1 = 5;
var num2 = num1;
num1 -= 1;
console.log(num2); // 5

对原来值的修改不会影响到新的值,同理对新值的修改也不会影响到原来的变量。

当从一个变量向另一个变量复制引用类型的值时,也会将变量对象中的值复制一份给新变量,但这个值的副本实际上是一个指针,这个指针指向存储在堆中的一个对象。两个变量实际上将引用同一个对象。

var obj1 = new Object();
var obj2 = obj1;
obj1.name = "Nicolas";
alert(obj2.name);   // "Nicolas"

改变其中一个变量,就会影响另外一个变量。

传递参数

ECMAScript中所有函数的参数都是按值传递的。

为了证明对象是按值传递的,看例子:

function setName(obj) {
    obj.name = "Nicholas";
    obj = new Object();
    obj.name = "Greg";
}
var person = new Object();
setName(person);
alert(person.name);     // "Nicholas"

原来的obj指向person对象,并添加了一个name属性。但第二行obj指向了一个新声明的对象。如果参数是引用传递的,那么外部的person会指向这个新的对象,但从结果来看,person并没有指向这个新的对象。

实际上,在函数内部重写obj时,这个变量引用的是一个局部对象,会在执行完毕后被销毁。

检测类型

虽然在检测基本类型时typeof是非常得力的助手,但在检测引用类型的值时,这个操作符的用处不大。

为此,ECMAScript提供了instanceof操作符

判断一个数组用instanceof,正则表达式也可以

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容