悟透Javascript undefined,null,"",0这四个值转换为逻辑值时就是false &this关键字

话题一:undefined,null,"",0这四个值转换为逻辑值时就是false

也就是在if判断时会把上面的五个作为false来判断。但是它们的类型确是不尽相同的,如下所示。

 typeof(undefined) == 'undefined'
 typeof(null) == 'object'
 typeof("") == 'string'
 typeof(0) == 'number'
 typeof(false) == 'boolean'

下面是案例来说明,逻辑值为false的情况。

<script type="text/javascript">
    function myFunc(){
        if(!undefined){
            alert("test1");
        }
        if(!null){
            alert("test2");
        }
        if(!""){
            alert("test3");
        }
        if(!0){
            alert("test4");
        }
        if(!false){
            alert("test5");
        }
    }
    myFunc();
</script>

这些都会通过判断,因为它们都表示false。

另外再补充一下

"123" == 123 返回true
"123" === 123 返回false

三个等于号表示完全等,类型也要相等,前面的一二三表示字符串,后面的是数字。

话题二:Javascript中的函数与变量的关系?

javascript中,函数就是变量,函数体就是变量内容。
javascript执行引擎并非一行一行地分析和执行程序,而是一段一段地分析执行的。在同一段程序分析执行中,定义式的函数语句会被提取出来优先执行。
函数定义执行完之后,才会按照顺序执行其他语句代码。

案例一:

<script type="text/javascript">
        function myfunc(){
            alert("hello");
        }
        myfunc();

        function myfunc(){
            alert("yeah");
        }
        myfunc();
    </script>

这段代码两次执行结果都是yeah,这就验证了刚才所说的了。前面的函数被后面覆盖了。

案例二:

<script type="text/javascript">
        function myfunc(){
            alert("hello");
        }
        myfunc();
    </script>
    <script type="text/javascript">
        function myfunc(){
            alert("yeah");
        }
        myfunc();
    </script>

就会先执行hello,然后执行yeah了。因为分成两段,就一段一段执行了。这里要能去想象javascript解释器的工作机制。

案例三:

<script type="text/javascript">
        function myfunc(){
            alert("hello");
        }
        myfunc();
        var myfunc = function(){
            alert("yeah");
        }
        myfunc();
    </script>

会先hello,然后yeah,为什么呢。因为第二个是定义变量的方式定义函数,不会优先执行。所以不会覆盖掉之前的函数。

话题三:javascript作用域?

var myName = "zhang";
就定义了window作用域的一个变量myName。
myName = "zhang";
就定义了window对象的一个属性myName。
两者几乎没有区别。对于全局的Javascript语句来说,加不加"var"都无所谓,但是对于一个函数体,就有区别了。
案例:

<script type="text/javascript">
    var yourName = '王菲';//定义变量
    myName = 'Jim';//定义属性
    alert(myName+" like "+yourName);//输出"Jim like 王菲"
    ChangeNames();
    function ChangeNames(){
        alert("Your old name is "+yourName);//输出"Your old name is undefined"
        alert("My old name is "+myName);//输出"My old name is Jim"
        var yourName = "李亚鹏";
        myName = "JiQing";
        alert(myName+" like "+yourName);//输出"JiQing like 李亚鹏"
    }
    alert(myName+" like "+yourName);//输出"JiQing like 王菲"
</script>

这里面可以看出,定义成var的格式,函数里的yourName与函数外的yourName没有关系。
而没有定义成var的格式,函数里的变量和外的是相关联的,是一个东西,里面变化了,外面也收到影响。
比如myName。
当代码运行进入一个函数时,Javascript会创建一个新的作用域。变量名最好加个"var",这样作用域不容易产生混淆。

话题四:函数和对象

 1.任何一个函数都可以为其动态地添加或去除属性。函数具有对象性。

案例:

<script type="text/javascript">
    function Sing(){
        alert(Sing.author+" : "+Sing.poem);
    }
    Sing.author = "李白";
    Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归。";
    Sing();//输出"李白:汉家秦地月,流影照明妃。一上玉关道,天涯去不归。"
    Sing.author = "李战";
    Sing.poem = "日出汉家天,月落阴山前。女儿琵琶怨,已唱三千年。";
    Sing();//输出"李战:日出汉家天,月落阴山前。女儿琵琶怨,已唱三千年。"
</script>

2.对象和函数的波粒二象性,即有数组的特点又有对象属性的特点

案例:

<script type="text/javascript">
    var anObject = {};
    anObject.aProperty = "Property of object";
    anObject.aMethod = function(){
        alert("Method of object");
    }
    alert(anObject["aProperty"]);//输出"Property of object"
    anObject["aMethod"]();//输出"Method of object"
    alert(anObject.aProperty);//输出"Property of object"
    anObject.aMethod();//输出"Method of object"
</script>

既可以以数组的方式输出,又可以以对象属性的方式输出。

话题五:this关键字

 在Javascript函数中,你只能把this看成当前服务的"这个"对象。

<script type="text/javascript">
    function WhoAmI(){
        alert("I'm "+this.name+" of "+typeof(this));
    }
    WhoAmI();//this是window
    var BillGates = {name:"Bill Gates"};
    BillGates.WhoAmI = WhoAmI;//将函数WhoAmI作为BillGates的方法
    BillGates.WhoAmI();//this是BillGates

    var SteveJobs = {name:"SteveJobs"};
    SteveJobs.WhoAmI = WhoAmI;
    SteveJobs.WhoAmI();//this是SteveJobs

    WhoAmI.call(BillGates);//直接将BillGates作为this,调用WhoAmI
    WhoAmI.call(SteveJobs);//直接将SteveJobs作为this,调用WhoAmI

    BillGates.WhoAmI.call(SteveJobs);//this是SteveJobs,调用BillGates的WhoAmI方法
    SteveJobs.WhoAmI.call(BillGates);//this是BillGates,调用SteveJobs的WhoAmI方法

    WhoAmI.WhoAmI = WhoAmI;//将函数WhoAmI作为WhoAmI的方法
    WhoAmI.name = "WhoAmI";
    WhoAmI.WhoAmI();
</script>

 

 

posted @ 2013-06-21 14:33  TBHacker  阅读(620)  评论(0编辑  收藏  举报