[转]《精通Javascript》笔记:第一至四章
《精通Javascript》笔记:第一至四章
- 保证你的代码不受其他Javascript代码影响(也不影响其他代码)的最常见的一个技巧是使用命名空间。
- JSAN(Javascript Archive Network)给库的规划提供了一套一致的规则。
- Yahoo的分级浏览器支持策略:http://developer.yahoo.com/yui/articles/gbs/index.html
- 类型检查的两种方法: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.’); } } }
- 在JavaScript里,作用域是由函数划分的。
- 名词理解:隐式全局作用域的变量声明。
- 闭包:内层的函数可以引用存在于包围它的函数内的变量,即使外层函数的执行已经结束。Jim Jey 的 Javascript Closures
- Currying:一种通过把多个参数填充到函数体中,实现将函数转换为一个新的经过简化的函数的技术。
- 闭包允许你引用父函数中的变量,但提供的值并非改变量创建时的值,而是在父函数范围内的最终值。
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); }; })(); }
- 上下文对象是通过this变量体现的,这个变量永远指向当前代码所处的对象中。
- 任何函数都可以被实例化为一个对象。
- 私有方法(private method)和私有变量只允许其他的私有方法、私有变量和特权方法访问。Private Members in Javascript
- 特权方法(privileged method)是动态生成的,因为它们是在运行时才添加到对象中的,而不是在代码第一次编译时就已经生成的。对比prototype上绑定方法开销更大,但功能也更强大、更灵活。
this.method = function() {}
- 静态方法与其他一般函数的主要区别在与,它是以对象的静态属性形式存在的。作为一个属性,它们不能在该对象的实例的上下文中访问,而只属于主对象本身的那个上下文中。
obj.method=function(){}
- 原型式继承,继承所有的方法和属性
function Person() {} function User() {} User.prototype = new Person();
- 类式继承:Douglas Crockford的模拟函数 Dean的Base库
- 代码清理:JSLint JSLint清理规则
- 代码压缩:JSMin Packer(Packer生成的代码会多出几百字节的内容,用于进行自解压)
- 调试:View Rendered Source Firebug Venkman
- 测试:JSUnit J3Unit Test.Simple
作者:QLeelulu
出处:http://QLeelulu.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利
出处:http://QLeelulu.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利