标签:UNC 效率 math 避免 rip 调用 而不是 最大 缺陷
定义全局的变量和函数,会影响代码的可维护性。如果在页面中运行的javascript 代码是在相同的作用域里面,那就可能代码之间存在互相影响的可能性。
有很多种手段可以解决因为定义了全局变量而导致代码"污染"的问题。
var myTes={
length:0‘
init:function(){...},
action:function(){...}
}
(function()
{
var length=0;
function init(){...}
function action(){...}
})()
所有的逻辑都包含在了这个立即执行的匿名函数中,形成了一个独立的模块,最大限度的防止了代码之间的"污染"。当然,在实际的业务中,模块之间会有交互,这时可使用return语句,返回需要公开的接口。
var myDocument=(function()
{
var length=0;
function init(){...}
function action(){...}
return {
init:init
}
})();
外部代码访问init()方法时,就可以调用myDocument.init了。此代码巧妙地做到了代码逻辑的封装,又公开了外部需要访问的接口,是模块化最佳实践之一。
(function()
{
length=0;
function init(){...}
function action(){...}
}
)()
//对象创建
var persion=new Object();
person.age=23;
person.name=‘daniel‘;
改为:
var person={age:23,name:‘daniel‘};
//数组创建
var list=new Array();
list[0]=12,
list[1]=20;
list[2]=24;
改为:
var list=[12,20,24];
在javascript中,with语句可用来快捷地访问对象地属性。with语句地格式如下:
with(object)
{
.......
}
with语句地原理是:javascirpt解析和运行时,会给with语句单独建立一个作用域,而和with语句结合的属性则成为了此作用域的局部变量,因此可直接访问。例如:
with(Math)
{
a=PI*r*r;
}
以下代码等同于以上代码
a=Math.PI*r*r;
使用with语句确实简化了代码,但使用with语句可能也会带了一些bug已经兼容问题
function f(x,o)
{
with(o)
{
print(x);
}
}
以上with语句中的x,可能来自于参数x,也可能来自o参数上的x属性。
2.with语句的设计方面也有缺陷,在with语句内部修改和with语句结合的对象后,并不能同步到with内部,即不能保证对象数据的一致性。例如:
var group ={
value:{
node:1
}
};
with(group.value)
{
group.value={
node:2
};
//显示错误:1
console.log(node);
}
//显示正确:2
console.log(group.value.node);
如果通过变量来获取某个对象的属性值,可以使用eval(‘obj.‘+key);
其实可以使用下标法取得属性值:obj[key]
2. eval的使用也存在安全性问题,因为它会执行任意传入的代码,而传入的代码有可能是未知的或者来自不受控制的源。
设立严格模式的目的主要是为了消除javascript语法上不合理的地方,从而提高代码安全性、编译效率、增加运行速度且更好地兼容javacscript未来的新版本。
严格模式主要是针对如下不合理的地方做了改进,包括:禁用with关键字、防止意外的全局变量、函数中的this 不再默认指向全局、防止函数参数重名、防止对象 属性重名、更安全的使用eval等。
启用严格模式很简单,主要在代码中添加如下代码即可:
"use strict";
使用严格模式时需要遵循的几条最佳实践。
为了兼容一些老代码,最好不要全局启用严格模式,如果想给大量的代码设置严格模式,则可以把代码包含在一个立即执行的函数中,并在函数开头启用严格模式,示例代码如下:
(function(){
"use strict"
// ..........
})();
2. 如果要更严格地编写javascript代码,可以使用javascript代码检查工具。目前最流行的检查工具主要是JSLint和JSHint。
标签:UNC 效率 math 避免 rip 调用 而不是 最大 缺陷
原文地址:https://www.cnblogs.com/cby-love/p/12079878.html