V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
isbase

遇到一个 JavaScript 运算符的问题

  •  
  •   isbase ·
    PRO
    · Sep 16, 2015 · 2746 views
    This topic created in 3887 days ago, the information mentioned may be changed or developed.

    菜鸟一枚,不明白下面这两段代码为什么会输出不同的结果

    var yun = new Object ()
    yun.name = "bai";
    yun.age = 199;
    
    function showPro (obj ) {
        var result = "";
        for (var clone in obj )
                result = clone + "=" + obj[clone];
            }
        }
        return result;
    }
    console.log (showPro (yun ));    // age=99
    
    
    function showPro (obj ) {
        var result = "";
        for (var clone in obj )
                result += clone + "=" + obj[clone];
            }
        }
        return result;    // name=bai age=199
    }
    
    14 replies    2015-09-17 09:40:40 +08:00
    jarlyyn
        1
    jarlyyn  
       Sep 16, 2015 via Android
    += 和=的区别吧?
    answeryou
        2
    answeryou  
       Sep 16, 2015
    第一个函数里是重新赋值
    第二个函数里是累加赋值
    isbase
        3
    isbase  
    OP
    PRO
       Sep 16, 2015
    @answeryou
    @jarlyyn

    我只是不明白为什么第二个函数里的 result += clone + "=" + obj[clone];

    我的理解是 result 不是空字符串吗?
    isbase
        4
    isbase  
    OP
    PRO
       Sep 16, 2015
    ```
    var yun = new Object ()
    yun.name = "bai";
    yun.age = 199;

    function showPro (obj ) {
    var result = "";
    for (var clone in obj )
    result = clone + "=" + obj[clone];
    }
    }
    return result;
    }
    console.log (showPro (yun )); // age=199


    function showPro (obj ) {
    var result = "";
    for (var clone in obj )
    result += clone + "=" + obj[clone];
    }
    }
    return result; // name=bai age=199
    }
    ```
    catoncat
        5
    catoncat  
       Sep 16, 2015
    第一次是空的,第二次不是空的。
    那是个 for 循环啊。
    catoncat
        6
    catoncat  
       Sep 16, 2015
    a+=b 就是 a = a + b
    循环里面 += ,就是每次都拼接新的在原来后面
    catoncat
        7
    catoncat  
       Sep 16, 2015
    = 就是无视原来的 重新赋值了
    isbase
        8
    isbase  
    OP
    PRO
       Sep 16, 2015
    @crs0910

    Thanks
    IFoon
        9
    IFoon  
       Sep 16, 2015
    重新看一下 C 语言的语法。
    isbase
        10
    isbase  
    OP
    PRO
       Sep 16, 2015 via Android
    @IFoon Why?
    an168bang521
        11
    an168bang521  
       Sep 16, 2015   ❤️ 1
    个人理解的代码:
    var yun ={};
    yun.name = "bai";
    yun.age = 199;
    function showPro (obj ) {
    var result = "";
    for (var clone in obj ){
    result = clone + "=" + obj[clone];//把等号右边计算后的值赋给等号左边的变量;记得 for-in 枚举出来的顺序是混乱的;枚举出来值的是第一次枚举出来的数值;
    }
    return result;
    }
    function showPro2 (obj ) {
    var result = "";
    for (var clone in obj ){
    //result += clone + "=" + obj[clone];//可以转化成下面一行的代码
    //result = result +(clone + "=" + obj[clone]);//这句和上面一句一样的;

    //下面两句和上面一行是一样的;
    result= ("age" + "=" + "199 ");//分解的第一步。值等于第一次枚举
    var result2=("name" + "=" +"bai ")+result;//分解的第二部,值等于第二次枚举的值+第一次枚举出来的值;
    }
    return result2;
    }
    console.log (showPro (yun )); // age=99
    console.log (showPro2 (yun )); // name=bai age=199
    shsf4
        12
    shsf4  
       Sep 16, 2015
    你试试 result=result+clone+"="+obj[clone];
    flydogs
        13
    flydogs  
       Sep 17, 2015   ❤️ 1
    第一个是循环里每次都重新赋值,所以最后一次有限
    第二个是循环里每次往 result 结尾+数据,所以是所有属性的结果。
    flydogs
        14
    flydogs  
       Sep 17, 2015
    有限=》有效
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   968 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 61ms · UTC 20:17 · PVG 04:17 · LAX 13:17 · JFK 16:17
    ♥ Do have faith in what you're doing.