当前位置: 代码迷 >> JavaScript >> js中或许你不知道的地方
  详细解决方案

js中或许你不知道的地方

热度:79   发布时间:2012-10-09 10:21:45.0
js中可能你不知道的地方
JavaScript是弱类型,除了在switch语句中。当JavaScript在case比较时,它是非弱类型
var myVar = 5;
if(myVar == '5'){ //返回true,因为JavaScript是弱类型
 alert("hi");  //这个alert将执行,因为JavaScript通常不在意数据类型
}
switch(myVar){
 case '5':
 alert("hi"); //这个alert将不会执行,因为数据类型不匹配
}



在window.onload执行document.write 会导致页面完全空白~
<div>123123123123123</div>
<div>123123123123123</div>
<div>123123123123123</div>
<div>123123123123123</div>
<script>
   window.onload = function(){
     document.write("");
   }
</script>


for in 会遍历原型链的属性和方法,可以用hasOwnProperty
for(var n in obj){
  if(obj.hasOwnProperty(n)){
    ...
   }
}

for in 适合处理自定义对象,如果是数组(Array),arguments,伪数组还是使用for

String(12) 返回的是字符串,new String(12) 返回的是object

每个对象会有__proto__属性,函数对象都有[[Scope]],__parent__ 属性

undefined 是 window 的一个属性,而null是一个object
if(flag){
    param = ( a == undefined ) ? 1 : 2;
}


    上面写法会存在一个问题,如果客户修改undefined的值,比如将undefined = 5,那么你的这种写法会出现问题,最好的方式是这样写

var undefined;
if(flag){
    param = ( a == undefined ) ? 1 : 2;
}


function a(x){
  x && a(--x);
  };
  var a;
alert(a);//function a(x){...}

然后略微修改一下
function a(x){
  x && a(--x);
  };
  var a = 1;
alert(a);//1

这种原理我还不知道用何种方式解释好,但这足以引起重视,如果当别人使用你的代码的时候,他起的变量名和你方法名一样,就会覆盖掉你的方法,解决方法,使用命名空间避免全局污染

数组的下标可以是一个object对象,例如
var key = {name:"cc"};
var key2 = {};
var arr = [];
arr[key] = "haha";
arr[key2] = "hehe";
alert(arr[key]);//hehe
alert(arr[{}]);//hehe
这里会有一个隐式转换,会调用对象的toString方法
如果想使用数组hash特性,可以重写对象toString方法,这样便可以利用数组来实现键值为对象map功能,对象同理

偷方法
使arguments变为数组,同理可使getElementsByTagName变为数组
var args = [].slice.call(arguments,0)

往对象里塞数组
var obj = {};
[].push.apply(obj,[1,2,4]);//{0:1,1:2,2:4,length:3}


暂时写这么多,欢迎大家提供分享~~
1 楼 king114963349 2011-09-05  
专注细节,裨益成败!!!
  相关解决方案