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

公司的项目突然很忙,看书的进度明显慢下来了,不过还是继续慢慢的学...

for in 语句可以用来遍历一个对象中的所有属性名。这个枚举过程将会列出所有的属性——包括函数和可能不关心的原型中的属性,所以有必要过滤那些不想要的值。最常用的过滤器是 hasOwnProperty 方法,以及使用 typeof 来排除函数:

var name;

for (name in another_stooge) {

if (typeof another_stooge[name] !== ‘function‘) {

document.writeln(name + ‘: ‘ + another_stooge[name]);

}

}

属性名出现的顺序是不确定的,因此要对任何可能出现的顺序有所准备。如果想要确保属性以特定的顺序出现,最好的办法就是完全避免使用 for in 语句,而是创建一个数组,在其中以正确的顺序包含属性名:

var i;

var properties = [

‘first-name‘,

‘middle-name‘,

‘last-name‘,

‘profession‘

];

for (i = 0; i < properties.length; i++) {

document.writeln(properties[i] + ‘: ‘ + another_stooge[properties[i]]);

}

通过使用 for 而不是 for in,可以得到我们想要的属性,而不用担心可能发掘出原型链中的属性,并且我们按正确的顺序取得了它们的值。


delete 运算符可以用来删除对象的属性。如果对象包含该属性,那么该属性就会被移除,它不会触及原型链中的任何对象。

删除对象的属性可能会让来自原型链中的属性透现出来。

delete another_stooge.nickname;


减少全局变量污染

JavaScript可以很随意的定义全局变量来容纳应用的所有资源。但是全局变量削弱了程序的灵活性,应避免使用。

最小化使用全局变量的方法之一是为应用只创建一个唯一的全局变量:

var MYAPP = {};

这时这个变量编程了应用的容器:

MYAPP.stooge = {

"first-name": "Joe",

"last-name": "Howard"

};

MYAPP.flight = {

airline: "Oceanic",

number: 815,

departure: {

IATA: "SYD",

time: "2014-11-18 16:50",

city: "Beijing"

},

arrival: {

IATA: "SYD",

time: "2014-11-18 16:50",

city: "Beijing"

}

};

只要把全局性的资源都纳入一个名称空间之下,你的程序与其他应用程序、组件或类库之间发生冲突的可能性就会显著降低。

时间: 12-07

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

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

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

&lt;JavaScript语言精粹&gt;-读书笔记(一)

用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语言精粹 读书笔记(一)

JavaScript中的“严格模式”. 如果在脚本文件的第一行加入"use strict";  则整个脚本都将以“严格模式”运行.如果语句不在第一行,则无效,整个脚本以“正常模式”运行.PS:只要"use strict"; 不跟在实际运行结果的语句后面,可以不在第一行. 如果"use strict"; 放在一个函数体的第一行,则整个函数以“严格模式”运行. “严格模式”的意义 - 消除Javascript语法的一些不合理.不严谨之处,减少一些怪异

《javascript设计模式》读书笔记二(封装和隐藏信息)

1.为什么要封装和信息隐藏 做过编程的朋友们知道"耦合"这个词,其实封装的效果就是为了解耦,让类和类之间没有太多的联系,防止某一天修改某一类的时候,产生"多米骨诺牌效应". 我们可以把信息隐藏看成目的,把封装看成达到信息隐藏的技术.通过封装就可以把对象的内部数据表现形式和实现细节进行隐藏.就好比你会看电视,但是你不知道电视的内部结构一样.但是在javascript中没有任何内置的机制,所以我们还需做些处理,同样来模仿封装. 2.创建对象的方法 1)最简单的一种方法就

《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的值 */

R语言实战读书笔记(二)创建数据集

2.2.2 矩阵 matrix(vector,nrow,ncol,byrow,dimnames,char_vector_rownames,char_vector_colnames) 其中: byrow=TRUE/FALSE,表示按行填充还是按列填充,默认情况下是按列填充 2.2.4 数据框 1.attach,detach()和with() attach():将数据框加入搜索路径 detach():将数据框移除出搜索路径 with():赋值仅在括号内有效,如果想在括号外生效也可以,用<<- 2.

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)) {