JavaScript语言精粹 读书笔记(一)

JavaScript中的“严格模式”。

如果在脚本文件的第一行加入"use strict";  则整个脚本都将以“严格模式”运行。如果语句不在第一行,则无效,整个脚本以“正常模式”运行。PS:只要"use strict"; 不跟在实际运行结果的语句后面,可以不在第一行。

如果"use strict"; 放在一个函数体的第一行,则整个函数以“严格模式”运行。


“严格模式”的意义

- 消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为;

- 消除代码运行的一些不安全之处,保证代码运行的安全;

- 提高编译器效率,增加运行速度;

- 为未来新版本的Javascript做好铺垫。


     JavaScript中值被当作为假(false):

false;

null;

空字符串"";

数字  0;

数字 NaN;

其余都被当作真,包括true、字符串"false",以及其他对象。


for in语句中,应该在每次循环中,object的下一个属性名字符串被赋值给variable

通常在使用过程中要检测object.hasOwnProperty(variable)来确定这个属性名是该对象的成员,还是来自于原型链。

for (myvar in obj) {

if (obj.hasOwnProperty(myvar)) {

...

}

}


对象是属性的容器,其中每个属性都拥有名字和值。属性的名字可以是包括空字符串在内的任意字符串。属性值可以是除 undefined 值以外的任何值。

JavaScript里的对象是无类型(class-free)的。它对新属性的名字和属性的值没有限制。对象适合用于汇集和管理数据。对象可以包含其他对象,所以它们可以容易地表示成树状或图形结构。

JavaScript包含一种原型链的特性,允许对象继承另一个对象的属性。正确地使用它能减少对象初始化时消耗的时间和内存。


对象字面量提供了一种非常方便的创建新对象值的表示法。一个对象字面量就是包围在一对花括号中的零或多个“名值”对。对象字面量可以出现在任何允许表达式出现的地方。

var empty_object = {};

var stooge = {

"first-name":"Jerome",

"last-name":"Howard"

};

属性名可以为"first-name",但不能为first-name ,但可以为first_name 。如果属性名是一个合法的JavaScript标识符且不是保留字,则不强求用引号括住属性名。

属性值可以嵌套。如:

var flight = {

airline:"aaaaa",

departure:{

IATA:"SYD"

}

};

获取对象里包含的值,可以用在对象后加[],且方括号中写属性名;如果属性名是一个字符串字面量,而且是个合法的JavaScript标识符且不是保留字,则也可以用 . 表示法表示。优先用 . 表达式。

stooge["first-name"]      //"Jerome"

flight.departure.IATA      //"SYD"

如果检索一个不存在的属性的值,则返回 undefined。

可以使用 || 运算符填充默认值。

var middle = stooge["middle-name"] || "(none)";

var status = flight.status || "unknown";

如果尝试从 undefined 的成员属性中取值将会导致 TypeError 异常。这时可以通过 && 运算符来避免错误。

flight.equipment                       // undefined

flight.equipment.model             // throw "TypeError"

flight.equipment && flight.equipment.model     // undefined

对象里的值可以通过赋值语句赋值,如果对象之前没有拥有那个属性名,那么该属性就被扩充到对象中。


对象的传递是通过引用来传递的,它们永远不会被复制。

var x = stooge;

var nick = stooge.nickname;

x.nickname = "Curly";

则 nick 也为"Curly"。

时间: 11-17

JavaScript语言精粹 读书笔记(一)的相关文章

JavaScript语言精粹读书笔记- JavaScript对象

JavaScript 对象 除了数字.字符串.布尔值.null.undefined(都不可变)这5种简单类型,其他都是对象. JavaScript中的对象是可变的键控集合(keyed collections). 对象是属性的容器,其中每个属性都拥有名字和值. JavaScript中的对象是无类别的(class-free)的.它对新属性的名字和值没有约束. JavaScript包括一个原型链特性,允许对象继承另一对象的属性. 对象的检索: stooge[“first-name”]或者stooge.

<JavaScript语言精粹>-读书笔记(一)

用object.hasOwnProperty(variable)来确定这个属性名是否为该对象成员,还是来自于原型链. for(my in obj){ if(obj.hasOwnProperty(my)){ ... } } 思考:--用来遍历判断是否有该属性成员,当为一个string var="abcdef"一样的一个字符串时,通过JS代码判断其中是否含有我们需要的某一个字符,比如a,如果有就将其remove 一个属性存取表达式用于指定一个对象或数组的属性或元素. 对象字面量:一个对象字

JavaScript语言精粹读书笔记 - JavaScript函数

JavaScript是披着C族语言外衣的LISP,除了词法上与C族语言相似以外,其他几乎没有相似之处. JavaScript 函数: 函数包含一组语句,他们是JavaScript的基础模块单元,用于代码复用.信息隐藏和组合调用. 函数用于指定对象的行为. 函数对象Functions: 在JavaScript中函数就是对象.对象是"键值"对的集合并拥有一个连接到原型对象的隐藏连接. 对象字面量产生的对象连接到Object.prototype.函数对象连接到Function.prototy

JavaScript语言精粹 读书笔记(二)

公司的项目突然很忙,看书的进度明显慢下来了,不过还是继续慢慢的学... for in 语句可以用来遍历一个对象中的所有属性名.这个枚举过程将会列出所有的属性——包括函数和可能不关心的原型中的属性,所以有必要过滤那些不想要的值.最常用的过滤器是 hasOwnProperty 方法,以及使用 typeof 来排除函数: var name; for (name in another_stooge) { if (typeof another_stooge[name] !== 'function') {

《JavaScript语言精粹》笔记

Function.prototype.method=function(name,func){    this.prototype[name]=func;    return this;}//1.注释最好使用双斜杠而不是带*斜杠/*2.数字,js不区分整数类型,1和1.0是相等的 * NaN是一个数值,它表示一个不能产生正常结果的运算结果.NaN不等于任何值,包括它自己,可用isNaN(number)检查 * 值Infinity表示所有大于1.79769313486231570e+308的值 */

JavaScript语言精粹学习笔记

0.JavaScript的简单数据类型包括数字.字符创.布尔值(true/false).null和undefined值,其它值都是对象. 1.JavaScript只有一个数字类型,它在内部被表示为64位的浮点数.没有分离出整数,所以1和1.0的值相同. 2.NaN是一个数值,表示一个不能产生正常结果的运算结果.NaN不等于任何值,包括它本身.可以用函数isNaN(number)检测NaN,但是建议用isFinite()来检测某值是否是数字. typeof NaN === ‘number’   /

读《JavaScript语言精粹》笔记

一.一些写代码的注意事项 1.parseInt 的使用 因为在八进制中,8和9不是数字,所以 parseInt("08") parseInt("09") 都会产生0作为结果,会导致程序解析时间和日期出现错误.所以建议使用parseInt将10传入. parseInt("08", 10) 的结果为8 2.当使用for in 循环时,最好加上 for (myvar in obj) { if (obj.hasOwnProperty(myvar)) {

学习javascript语言精粹的笔记

1.枚举: 用for in 语句来遍历一个对象中所有的属性名,该枚举过程将会列出所有的属性也包括涵数和方法,如果我们想过滤掉那些不想要的值,最为常用的过滤器为hasOwnProperty方法,以及使用的typeof来排除, var name; for(name in another_stooge){ if(typeof another_stooge[name] !== "function"){ document.writeln(name + ":" + anothe

javascript 语言精粹 笔记推荐。。

http://www.cnblogs.com/Cohlint/archive/2012/11/26/2788790.html 这篇javascript 语言精粹 学习笔记不错..不过看上去就是读书笔记,没有深入研究某个点..比如闭包..我还是不懂噢.. 比如17条:“add_the_handles 函数目的是给每个时间处理器一个唯一值(i).它未能达到目的是因为事件处理器函数绑定了变量i,而不是函数在构造时的变量i的值.” 这是原书的翻译过来的理解,但是感觉还是很艰涩,不太理解. 闭包这个变量作