令人惊奇的JavaScript面向对象(一)

 

 

有种流行的说法:JavaScript是基于对象和事件驱动的。应该怎样理解“基于对象”的意思呢?

《精通JavaScript》告诉我们,对象是JavaScript的基础,甚至说“JavaScript这门语言就是完全面向对象的”。

 

我不知道应该怎样评判这样的说法,JavaScript确实有面向对象的特性,但是他的表现形式却和其他面向对象编程语言大相径庭。

 

 

在谈JavaScript的面向对象之前,我想先说说JavaScript的作用域问题。我想只有搞清楚这个问题,才能更好地理解接下来的内容。我将会用自己的理解将JavaScript中的面向对象特性与一般面向对象程序设计语言(Java/C++等)的一些称谓对应起来。

 

 

首先理清两个问题:

1.什么是全局变量?

JavaScript中的全局变量实际上指的是window对象下的对象属性。

2.作用域划分。

JavaScript中的作用域是基于上下文,以函数进行划分的,而不是由块(block)划分的。

 

接下来看一个例子(原例来自《精通JavaScript》,有改动):

< script type = " text/javascript " >

//  设置全局变量foo,并置为“test”
var  foo  =   " test " ;

if  (  true  )
ExpandedBlockStart.gifContractedBlock.gif
{
    
// 注意:现在还在全局作用域中
    var foo = "new test";
}


//  如我们所见,现在foo等于'new test'了
alert( foo );

//  创建一个会修改变量foo的新函数
function  test()
ExpandedBlockStart.gifContractedBlock.gif
{
    
//函数内部定义变量不影响全局变量
    var foo = "old test";
    
//隐式定义全局变量
    val = 'hello!';
}


//  然而在调用test函数时,foo只在函数作用域内起作用
test();

//  确认foo还是等于'new test'
alert( foo );

//  全局变量实际是window下的属性
alert( window.foo );

//  函数内部隐式定义的全局变量
alert(val);

< / script>

 

现在你大概对JavaScript的作用域有了一个初步的理解。

要强调的两点是:

1.在同一作用域中,JavaScript是允许变量的重复定义的,并且后一个定义将覆盖前一个定义。

2.函数内部如果不加关键字var而定义的变量,默认为全局变量。

 

 

今天先写到这里,明天我将会整理JavaScript中一些面向对象特性与大家分享。

 

 

转载于:https://www.cnblogs.com/zhengchuyu/archive/2008/07/22/1248286.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值