对象属性的名字能够是空字符串,属性值能够是undefined
(原文为属性值能够是除undefined
之外的任何值,可是测试能够为undefined
)。数组
尝试从undefined
的属性中取值会致使TypeError
,能够经过&&
运算符避免。(obj.name && obj.name.oldName)
浏览器
调用一个函数会暂停当前函数的执行,控制权转交给新的函数。每一个函数都接受两个附加的参数:this
和 arguments
。this
有四种调用状况再也不赘述。闭包
当一个函数运行时,它从第一个语句开始执行,并在遇到关闭函数体的}
时结束。return
语句可使函数提早返回,中断函数的运行。app
throw
语句也能中断函数的执行,而且抛出一个错误对象。函数
函数总会返回一个值。若是没有指定返回值,则返回undefined
。(任何语句都会返回值,在浏览器console面板执行语句后的值就是返回值)。性能
柯里化延迟调用,把函数看作一个值,在函数以前传递。测试
递归优化: 记忆。利用闭包创建一个储存区,避免重复运算。如优化
var fibonacci = function (n){ return n < 2 ? n : fibonacci(n - 1) + fibonacci(n - 2); } // 本身的代码 var fibonacci = (function (){ var memo = {}; return function (n){ if (n < 2) { return n; } if (!memo[n]) { memo[n] = fibonacci(n-1)+fibonacci(n-2); } return memo[n]; } })() // 书上原版 var fibonacci = function () { var memo = [0, 1]; var fib = function (n) { var result = memo[n]; if (typeof result !== 'number') { result = fib(n - 1) + fib(n - 2); memo[n] = result; } return result; }; return fib; }();
而后本身测试了一下性能,在大量运算的时候确实很厉害。一开始传了个100进去,而后浏览器就卡死了。。。
此外书中还提供了一个包装函数以下:this
var memoizer = function(memo, formula) { var recur = function(n) { var result = memo[n]; if (typeof result !== 'number') { result = formula (recur, n); } return result; } return recur; } 例如调用一个阶乘函数: var factorial = memoizer([1, 1], function(recur, n) { return n * recur (n - 1); })
区别数组和对象的好方法。Object.prototype.toString.apply(someObj)
返回一个'[object Array]'
或者'[object Object]'
.用constructor
不肯定性太多。instanceof
在iframe状况下不能正常工做。Array.isArray()
也是极好的,只是IE8下不兼容。spa
array.slice
方法对array
中的一段作浅复制,[obj,obj]
中的对象改变会反应在两个数组上。
array.shift
方法要比array.pop
慢上30%
左右。
自动插入分号,如:
return { some: 1 } // 直接执行了 return;
typeof null
返回'object'
。
其它的一些缺点由于已经习惯了就没放上来了。