保证你的代码不受其他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
转载于:https://www.cnblogs.com/QLeelulu/archive/2008/03/29/1128904.html