[转]《精通Javascript》笔记:第一至四章

《精通Javascript》笔记:第一至四章

Published by sansan at 10:40 am under 前端|Front-End

  1. 保证你的代码不受其他Javascript代码影响(也不影响其他代码)的最常见的一个技巧是使用命名空间。
  2. JSAN(Javascript Archive Network)给库的规划提供了一套一致的规则。
  3. Yahoo的分级浏览器支持策略:http://developer.yahoo.com/yui/articles/gbs/index.html
  4. 类型检查的两种方法:typeof, contructor
    // 用一个变量类型列表严格检查一个参数列表
    function strict(types, args) {
    	if (types.length != args.length) {
    		throw(’Invalid number of arguments.’);
    	}
    	for (var i=0; i<args.length; i++) {
    		if (args[i].constructor != types[i]) {
    			throw(’Invalid argument type.’);
    		}
    	}
    }
  5. 在JavaScript里,作用域是由函数划分的。
  6. 名词理解:隐式全局作用域的变量声明。
  7. 闭包:内层的函数可以引用存在于包围它的函数内的变量,即使外层函数的执行已经结束。Jim Jey 的 Javascript Closures
  8. Currying:一种通过把多个参数填充到函数体中,实现将函数转换为一个新的经过简化的函数的技术。
  9. 闭包允许你引用父函数中的变量,但提供的值并非改变量创建时的值,而是在父函数范围内的最终值。
    var obj = document.getElementById(’main’);
    var items = [’click’, ‘keypress’];
    for (var i=0; i<items.length; i++) {
    	(function(){
    		var item = items[i];
    		obj[’on’+item] = function() {
    			alert(’Thank you for your ‘ + item);
    		};
    	})();
    }
  10. 上下文对象是通过this变量体现的,这个变量永远指向当前代码所处的对象中。
  11. 任何函数都可以被实例化为一个对象。
  12. 私有方法(private method)和私有变量只允许其他的私有方法、私有变量和特权方法访问。Private Members in Javascript
  13. 特权方法(privileged method)是动态生成的,因为它们是在运行时才添加到对象中的,而不是在代码第一次编译时就已经生成的。对比prototype上绑定方法开销更大,但功能也更强大、更灵活。
    this.method = function() {}
  14. 静态方法与其他一般函数的主要区别在与,它是以对象的静态属性形式存在的。作为一个属性,它们不能在该对象的实例的上下文中访问,而只属于主对象本身的那个上下文中。
    obj.method=function(){}
  15. 原型式继承,继承所有的方法和属性
    function Person() {}
    function User() {}
    User.prototype = new Person();
  16. 类式继承:Douglas Crockford的模拟函数 Dean的Base库
  17. 代码清理:JSLint JSLint清理规则
  18. 代码压缩:JSMin Packer(Packer生成的代码会多出几百字节的内容,用于进行自解压)
  19. 调试:View Rendered Source Firebug Venkman
  20. 测试:JSUnit J3Unit Test.Simple
posted on 2008-03-29 15:40  Q.Lee.lulu  阅读(1151)  评论(0编辑  收藏  举报