javascript声明对象时 带var和不带var的区别

Javascript声明变量时

var aaa = 111;

aaa = 111;

两种方式一样吗?

废话少说,先上代码.

var aaa = 11;

function test4(){
    var aaa = 22;
}

test4();

console.log(aaa);

结果是什么呢? 11

这个好理解, 函数内的var aaa声明是内部变量,这时结果是第一个aaa的值.

变动一下如下:

var abc = 11;

function test4(){
    abc = 22;
}

test4();

console.log(abc);

结果是什么呢? 22

再改:

function test4(){
    var aaa = 22;
}

test4();

console.log(aaa);

结果怎样? 运行报错了! ReferenceError: aaa is not defined!

改:

function test4(){
    var aaa = 22;
}

test4();

console.log(test4.aaa);

运行不会报错,输出结果是 undefined.

结论1: 函数或者对象构造内声明的变量是私有的. 外部无法访问到. 包括原型继承后的对象. 

可是如果这样:

function test4(){
    bbb = 33;
}

test4();

console.log(bbb);

结果是 33

点解?

这就是有var 和没有 var的声明的区别.

结论2: 不加var 在函数或者构造内就是赋值, 从函数内往上一层层寻找变量bbb,一直到顶层没有. 就在顶层声明一个 var bbb;

很可怕假如一个大的项目,在这里改变了bbb的值, 并没有添加var 碰巧整个项目全局变量有个同名bbb被改变,不加var不是只作用在这个函数或对象内. 出了错误很难找.

所以书写代码必须谨慎. 声明变量改加的就加不能怕麻烦. 结果是完全不同的.

转载于:https://www.cnblogs.com/vincent2d/p/4886920.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值