对象
对象属性的名字可所以空字符串,属性值可所以
undefined
(原文为属性值可所以除undefined
之外的任何值,然则测试可认为undefined
)。尝试从
undefined
的属性中取值会致使TypeError
,能够经由过程&&
运算符防止。(obj.name && obj.name.oldName)
函数
挪用一个函数会停息当前函数的实行,控制权转交给新的函数。每一个函数都接收两个附加的参数:
this
和arguments
。this
有四种挪用状况不再赘述。当一个函数运转时,它从第一个语句最先实行,并在碰到封闭函数体的
}
时完毕。return
语句能够使函数提早返回,中缀函数的运转。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进去,然后浏览器就卡死了。。。
另外书中还供应了一个包装函数以下:
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下不兼容。
要领
array.slice
要领对array
中的一段做浅复制,[obj,obj]
中的对象转变会反应在两个数组上。array.shift
要领要比array.pop
慢上30%
摆布。
毒瘤
自动插进去分号,如:
return { some: 1 } // 直接实行了 return;
typeof null
返回'object'
。
别的的一些瑕玷由于已习惯了就没放上来了。