javascript面试题

var test=(function(){
    var _v='a';

    function changeV(){
        _v='b';
    };
    function getV(){
        return _v;
    }
    return {
        v:_v,
        changeV:changeV,
        getV:getV,
    }
})()

test.v//'a'
test.getV()//'a'
test.changeV()
test.v//'a'
test.getV()//'b'

test.changeV()发生了什么,
大神 来讲讲 (¬_¬)

回来填坑。。。:其实就是当时没理解

var _a=1;
var obj={
    a:_a
};
console.log(obj.a);//1
_a=2;
console.log(obj.a);//1
阅读 3.3k
4 个回答

v:_v, 这里是对return 的对象进行了一个属性的赋值,赋的是一个字符串,这时候不是对象,直接copy的值。

changeV和getV是闭包,操作的是_v这个变量。

string和number类型的数据只是在使用的时候被转化成对象,操作完成在内存中存的是其valueOf后的值。

var test=(function(){

var _v='a';  //私有变量

function changeV(){    //私有函数
    _v='b';
};
function getV(){
    return _v;
}
return {
    v:_v,              //公有属性
    changeV:changeV,   //公有方法
    getV:getV,         //公有方法
}

})()

test.v //输出公有属性
test.changeV() 公有方法更改私有变量

这其实是一个闭包的问题,changeV这个方法改变的是匿名函数作用域中的_v变量。可以将_v理解为是一个私有变量,只能通过changeV方法修改,通过getV方法获取。

var a = 'A',
    b = 'B';

b = a;
a = 'C';

请问b是多少?


然而b仍然为'A',给你补一下

JavaScript中的变量有5个基本数据类型(Undefined, Null, Boolean, Number,String)和引用数据类型(Object,Function,Array等)。
二者的区别主要在于对变量内容保存的方式,基本类型的变量中存储的就是简单的数据段,而引用类型变量存储的是指向对象的引用

变量 _v 是基本数据类型,所以赋值给 test.v 后,test.v 也是基本数据类型。因此不管怎么改变 _v ,test.v 都是不会变的,半毛钱关系没有。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题