易截截图软件、单文件、免安装、纯绿色、仅160KB

JavaScript面向对象编程

许多Web开发人员对JavaScript的了解仅仅停留在简单的表单数据操作,以及浏览器DOM对象的简单操作上,以达到一些数据验证和动态页面的效果。所以当要实现的功能比较复杂时,写出的代码就显得凌乱并且难以维护,更不用说实现一个基于JavaScript的UI框架了。事实上,JavaScript 提供了完善的机制来实现面向对象的开发思想。
本章假设读者已经了解面向对象思想的基本概念,熟悉对象、类、继承等基本术语。以此为基础,将重点介绍如何在 JavaScript 中使用面向对象的思想,包括实现的原理、机制和技巧。我们将使用JavaScript来实现以下面向对象特性:
¾ 对象、类;
¾ 封装;
¾ 多态;
¾ 继承。
1.对象
在JavaScript中创建一个对象非常简单,我们可以使用内建的Object对象来创建一个对象:
var myObj=new Object;    //创建一个名为myObj的对象
myObj.name='sam';         //给myObj对象添加一个name属性,其值为sam
myObj.age=28;             //给myObj对象添加一个age属性,其值为28
我们也可以使用JSON(JavaScript Object Notation)[1] 来创建一个对象:
var myObj={name:’sam’,age:28}
//创建一个包含name属性值为sam,age属性值为28的对象
2.类
JavaScript不同于Java、C++、C#等面向对象语言,它通过构造函数和原型对象(prototype)来实现类的创建。为了创建一个类,还需要创建一个构造函数:
function Person(name,age){
this.name=name;
this.age=age;
}
这样我们就创建了一个构造函数(类),它包含两个属性:name和age。
var sam=new Person('sam',28);   //创建一个Person对象,name为sam,age为28
我们可以通过“.”运算符来访问它的属性:
alert(sam.name);   //输出结果为sam
var bob=new Person('bob',30);   //创建一个Person对象,name为bob,age为30
alert(bob.age);   //输出结果为30
细心的读者可能会发现,到目前为止,我们通过函数创建的对象只是封装了数据成员,并没有封装相应的方法。下面我们将在Person类中添加一个方法:
function Person(name,age){
this.name=name;
this.age=age;
this.introduceSelf=function(){
alert('I am '+name+' , I am '+age +' years old.');
}
}
var sam=new Person('sa


相关文档:

JavaScript类和继承:constructor属性

constructor属性始终指向创建当前对象的构造函数。比如下面例子:
// 等价于 var foo = new Array(1, 56, 34, 12);
 
var arr = [
1

56

34

12
];  
console.log(arr.constructor === Array);  ......

javaScript循序渐进(3)


<!--
@page { margin: 2cm }
P { margin-bottom: 0.21cm }
-->
闭包(
closure

闭包意味着内层的函数可以引用存在于包围他的函数内的变量,即使外层函数的执行已经终止。这个特性非常强大和复杂。
 
例如:闭包如何使代码更清晰的两个例子
找出
ID
为‘
main’
的元素
var ......

Javascript的常用语句

1. document.write( " "); 输出语句
2.JS中的注释为//
3.传统的HTML文档顺序是:document- >html- >(head,body)
4.一个浏览器窗口中的DOM顺序是:window- >(navigator,screen,history,location,document)
5.得到表单中元素的名称和值:document.getElementById( "表单中元素的ID號 &quo ......

javaScript 文本效果

功能:文本控件里的文本,当鼠标进入时:选中文本;当鼠标按下时:清空文本;当鼠标移出控件外点击:文本还原。
<textarea id="tbox" runat="Server" class="tbox" cols="20" rows="8" onmouseover="this.focus();" onfocus="this.select();" o ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号