码迷,mamicode.com
首页 > Web开发 > 详细

js一些要点

时间:2014-10-12 20:54:58      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   使用   ar   for   strong   

js中:

undefined == null   --> true

false == null          --> false

false == undefined --> false

 

关于js立即执行函数:

function (){ /*codde*/ }();
function aa(){/*codde*/}();

这样不会执行并且抛出异常

(function aa(){/*codde*/}());
(function aa(){/*codde*/})();

都是正确方式,推荐第一种。

 

js中普通对象 和 new函数()对象 以及 普通函数() 区别

1,普通函数(),表示执行一次函数,返回结果为内部return的结果。没有为undefined

2,var a = new 函数(),也会执行一次函数,但会将执行完后的函数上下文作为一个对象返回给a,可以通过a.i 调用函数内部this.i声明的内部变量(这就是声明属性的方法)。(单纯的var i只是局部变量,不是属性)。

3,var a = {}普通对象,通过a.i引用内部i:value方式的值。

 

函数内变量作用域:

函数内 var i=0;是局部变量,能屏蔽全局上的i变量。

但函数内直接使用 i=0;表示一个全局变量。

 

js中闭包的典型用法:

1 <input type=‘button‘ id=‘b1‘/>  
2 <input type=‘button‘ id=‘b2‘/>  
3 <input type=‘button‘ id=‘b3‘/>  

上面3个button,功能一样——每当被点击,就alert出自己目前为止一共被点击了多少次; 
那么这个记录点击次数的变量放在哪里?这3个button的功能完全一样,事件函数可以写成一个,但却需要分别设立变量来存储自己被点击了多少次,那么这个时候闭包的作用就来了:把他们的事件监听函数设置为同一个函数的闭包,这样一来3个button的点击次数就独立变化了,且没有全局变量产生; 

就像下面这样的代码: 

function genCount(){
    var i = 0;
    return function(){
        i++;
        alert(i);
    }
}
var a = genCount();
var b = genCount();
a();
b();
b();
b();
a();

上述例子,来自该贴中pf_miles的回帖:http://www.iteye.com/topic/569395

还有一个例子,代码比较长,地址在这里:http://blog.chinaunix.net/uid-13164110-id-3066361.html

 

以后还是得多写博客,不然记得好好的东西说忘就忘

 

js一些要点

标签:style   blog   http   color   io   使用   ar   for   strong   

原文地址:http://www.cnblogs.com/lordrobert/p/4020774.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!