JavaScript 类的定义和引用 JavaScript高级培训 自定义对象


Posted in Javascript onApril 27, 2010

一,概述

在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类、Hashtable类等等。

目前在Javascript中,已经存在一些标准的类,例如Date、Array、RegExp、String、Math、Number等等,这为我们编程提供了许多方便。但对于复杂的客户端程序而言,这些还远远不够。

与Java不同,Java2提供给我们的标准类很多,基本上满足了我们的编程需求,但是Javascript提供的标准类很少,许多编程需求需要我们自己去实现,例如Javascript没有哈西表Hashtable,这样的话在处理键值方面就很不方便。

因此,我个人认为一个完整的Javascript对象视图应该如下:

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

二,基本概念

1,自定义对象。
根据JS的对象扩展机制,用户可以自定义JS对象,这与Java语言有类似的地方。
与自定义对象相对应的是JS标准对象,例如Date、Array、Math等等。
2,原型(prototype)
在JS中,这是一种创建对象属性和方法的方式,通过prototype可以为对象添加新的属性和方法。
通过prototype我们可以为JS标准对象添加新的属性和方法,例如对于String对象,我们可以为其添加一个新的方法trim()。
与严格的编程语言(例如Java)不同,我们可以在运行期间为JS对象动态添加新的属性。

三,语法规则

1,对象创建方式

1)对象初始化器方式

格式:objectName = {property1:value1, property2:value2,…, propertyN:valueN}
property是对象的属性
value则是对象的值,值可以是字符串、数字或对象三者之一
例如: var user={name:“user1”,age:18};
    var user={name:“user1”,job:{salary:3000,title:programmer}
以这种方式也可以初始化对象的方法,例如:
    var user={name:“user1”,age:18,getName:function(){
                return this.name;
          }         
    }
后面将以构造函数方式为重点进行讲解,包括属性和方法的定义等等,也针对构造函数的方式进行讲解。

2)构造函数方式

编写一个构造函数,并通过new方式来创建对象,构造函数本可以带有构造参数
例如:
function User(name,age){
          this.name=name;
          this.age=age;
          this.canFly=false;
    }
    var use=new User();

2,定义对象属性

1)JS中可以为对象定义三种类型的属性:私有属性、实例属性和类属性,与Java类似,私有属性只能在对象内部使用,实例属性必须通过对象的实例进行引用,而类属性可以直接通过类名进行引用。

2)私有属性定义
私有属性只能在构造函数内部定义与使用。
语法格式:var propertyName=value;
例如:
function User(age){
           this.age=age;
           var isChild=age<12;
           this.isLittleChild=isChild;
    }
    var user=new User(15);
    alert(user.isLittleChild);//正确的方式
    alert(user.isChild);//报错:对象不支持此属性或方法

3)实例属性定义,也存在两种方式:
prototype方式,语法格式:functionName.prototype.propertyName=value
this方式,语法格式:this.propertyName=value,注意后面例子中this使用的位置
上面中value可以是字符创、数字和对象。
例如:
function User(){ }
User.prototype.name=“user1”;
User.prototype.age=18;
var user=new User();
alert(user.age);
—————————————?
function User(name,age,job){
         this.name=“user1”;
         this.age=18;
         this.job=job;
    }
    alert(user.age);

3)类属性定义
语法格式:functionName.propertyName=value
例如:
function User(){ }
User.MAX_AGE=200;
User.MIN_AGE=0;
alert(User.MAX_AGE);
参考JS标准对象的类属性:
Number.MAX_VALUE //最大数值 Math.PI //圆周率

4)对于属性的定义,除了上面较为正规的方式外,还有一种非常特别的定义方式,语法格式: obj[index]=value
例子:
     function User(name){
             this.name=name;
             this.age=18;
             this[1]=“ok”;
             this[200]=“year”;
     }
     var user=new User(“user1”);
     alert(user[1]);
     在上面例子中,要注意:不同通过this[1]来获取age属性,也不能通过this[0]来获取name属性,即通过index方式定义的必须使用index方式来引用,而没有通过index方式定义的,必须以正常方式引用

3,定义对象方法

1)JS中可以为对象定义三种类型的方法:私有方法、实例方法和类方法,与Java类似:
私有方法只能在对象内部使用
实例方法必须在对象实例化后才能使用
类方法可以直接通过类名去使用
注意:方法的定义不能通过前面所说的index方式进行。
2)定义私有方法
私有方法必须在构造函数体内定义,而且只能在构造函数体内使用。
语法格式:function methodName(arg1,…,argN){ }
例如:
function User(name){
          this.name=name;
          function getNameLength(nameStr){
              return nameStr.length;
          }
          this.nameLength=getNameLength(this.name);   
    }
3)定义实例方法,目前也可以使用两种方式:
prototype方式,在构造函数外使用,语法格式:
functionName.prototype.methodName=method;
或者
functionName.prototype.methodName=function(arg1,…,argN){};
this方式,在构造函数内部使用,语法格式:
this.methodName=method;
或者
this.methodName=function(arg1,…,argN){};
上面的语法描述中,method是外部已经存在的一个方法,methodName要定义的对象的方法,意思就是将外部的一个方法直接赋给对象的某个方法。
以function(arg1,…,argN){}的方式定义对象方法是开发人员应该掌握的。

定义实例方法的一些例子:例子1
function User(name){
       this.name=name;
       this.getName=getUserName;
       this.setName=setUserName;
}
function getUserName(){
       return this.name;
}
Function setUserName(name){
       this.name=name;
}

定义实例方法的一些例子:例子2
function User(name){
       this.name=name;
       this.getName=function(){
               return this.name;
       };
       this.setName=function(newName){
               this.name=newName;
       };
}

定义实例方法的一些例子:例子3
function User(name){
       this.name=name;
}
User.prototype.getName=getUserName;
User.prototype.setName=setUserName();
function getUserName(){
       return this.name;
}
Function setUserName(name){
       this.name=name;
}

定义实例方法的一些例子:例子4
function User(name){
       this.name=name;
}
User.prototype.getName=function(){
       return this.name;
};
User.prototype.setName=function(newName){
       this.name=newName;
};

4)定义类方法
类方法需要在构造函数外面定义,可以直接通过构造函数名对其进行引用。
语法格式:
functionName.methodName=method;
或者
functionName.methodName=function(arg1,…,argN){};
例子:
function User(name){
            this.name=name;
    }
    User.getMaxAge=getUserMaxAge;
    function getUserMaxAge(){
           return 200;
    }
    或者
    User.getMaxAge=function(){return 200;};
    alert(User.getMaxAge());

4,属性与方法的引用

1)从可见性上说:
私有属性与方法,只能在对象内部引用。
实例属性与方法,可以在任何地方使用,但必须通过对象来引用。
类属性与方法,可以在任何地方使用,但不能通过对象的实例来引用(这与Java不同,在Java中静态成员可以通过实例来访问)。
2)从对象层次上说:
与Java bean的引用类似,可以进行深层次的引用。
几种方式:
简单属性:obj.propertyName
对象属性:obj.innerObj.propertyName
索引属性:obj.propertyName[index]
对于更深层次的引用与上面类似。
3)从定义方式上说:
通过index方式定义的属性,必须通过index方式才能引用。
通过非index方式定义的属性,必须通过正常的方式才能引用。
另外注意:对象的方法不能通过index方式来定义。

5,属性与方法的动态增加和删除
1)对于已经实例化的对象,我们可以动态增加和删除它的属性与方法,语法如下(假定对象实例为obj):
动态增加对象属性
obj.newPropertyName=value;
动态增加对象方法
    obj.newMethodName=method或者=function(arg1,…,argN){}
动态删除对象属性
    delete obj.propertyName
动态删除对象方法
    delete obj.methodName

2)例子:
    function User(name){
             this.name=name;
             this.age=18;
    }
    var user=new User(“user1”);
    user.sister=“susan”;
    alert(user.sister);//运行通过
    delete user.sister;
    alert(user.sister);//报错:对象不支持该属性

    user.getMotherName=function(){return “mary”;}
    alert(user.getMotherName());//运行通过
    delete user.getMotherName;
    alert(user.getMotherName());//报错:对象不支持该方法

四,总结

1,自定义对象机制,是JS最为吸引人的机制之一,对于C++和Java程序员而言,这简直太棒了!
2,对象创建存在两种方式:对象初始化器和构造函数。
3,对象属性和方法,具有可见性的约束,不同可见性的属性和方法,其定义方式也不一样。

  JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

五,应用案例

下面将采用一个应用案例:网上购物商城
应用案例的实现步骤:
1,场景设计

1)登录场景

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

2)购物场景

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

3)结算场景

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

2,界面设计

1)登录页面

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

2)购物页面

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

3)结算页面

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

3,类图设计

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

4,代码实现

1)Product类

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

2)ShoppingCart类

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
3)ShoppingSession类

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象

4)ShoppingCartParser类

JavaScript 类的定义和引用 JavaScript高级培训 自定义对象 

原文地址:http://www.ccvita.com/94.html 作者:kimi Chen

Javascript 相关文章推荐
jQuery Flash/MP3/Video多媒体插件
Jan 18 Javascript
基于jquery的分页控件(C#)
Jan 06 Javascript
javascript中比较字符串是否相等的方法
Jul 23 Javascript
鼠标悬停小图标显示大图标
Jan 22 Javascript
详解vue父子组件间传值(props)
Jun 29 Javascript
jQuery实现获取table中鼠标click点击位置行号与列号的方法
Oct 09 jQuery
vue与bootstrap实现简单用户信息添加删除功能
Feb 15 Javascript
koa-router路由参数和前端路由的结合详解
May 19 Javascript
AntV F2和vue-cli构建移动端可视化视图过程详解
Oct 08 Javascript
一篇文章带你使用Typescript封装一个Vue组件(简单易懂)
Jun 05 Javascript
javascript实现前端成语点击验证优化
Jun 24 Javascript
vue+spring boot实现校验码功能
May 27 Vue.js
jQuery EasyUI 中文API Layout(Tabs)
Apr 27 #Javascript
基于jquery实现的服务器验证控件的启用和禁用代码
Apr 27 #Javascript
jQuery 表格插件整理
Apr 27 #Javascript
jquery 事件对象属性小结
Apr 27 #Javascript
Google排名中的10个最著名的 JavaScript库
Apr 27 #Javascript
基于jquery的让页面控件不可用的实现代码
Apr 27 #Javascript
JQuery上传插件Uploadify使用详解及错误处理
Apr 27 #Javascript
You might like
PHP仿博客园 个人博客(1) 数据库与界面设计
2013/07/05 PHP
解决laravel中日志权限莫名变成了root的问题
2019/10/17 PHP
js判断浏览器的比较全的代码
2007/02/13 Javascript
脚本合并提升javascript性能示例
2014/02/24 Javascript
javascript制作坦克大战全纪录(2)
2014/11/27 Javascript
JS实现屏蔽shift,Ctrl,alt等功能键的方法
2015/06/01 Javascript
JavaScript实现点击文本自动定位到下拉框选中操作
2016/06/15 Javascript
NPM 安装cordova时警告:npm WARN deprecated minimatch@2.0.10: Please update to minimatch 3.0.2 or higher to
2016/12/20 Javascript
angular学习之ngRoute路由机制
2017/04/12 Javascript
nodejs socket实现的服务端和客户端功能示例
2017/06/02 NodeJs
AngularJS中table表格基本操作示例
2017/10/10 Javascript
vue基于element的区间选择组件
2018/09/07 Javascript
Vue.js上传图片到阿里云OSS存储的方法示例
2018/12/13 Javascript
JS实现页面跳转与刷新的方法汇总
2019/08/30 Javascript
[14:51]DOTA2 HEROS教学视频教你分分钟做大人-卓尔游侠
2014/06/13 DOTA
使用Python中的线程进行网络编程的入门教程
2015/04/15 Python
Python模块搜索概念介绍及模块安装方法介绍
2015/06/03 Python
Python爬虫实战:分析《战狼2》豆瓣影评
2018/03/26 Python
在Django中输出matplotlib生成的图片方法
2018/05/24 Python
在python中用url_for构造URL的方法
2019/07/25 Python
docker-py 用Python调用Docker接口的方法
2019/08/30 Python
python实现多线程端口扫描
2019/08/31 Python
pycharm修改file type方式
2019/11/19 Python
Python HTMLTestRunner可视化报告实现过程解析
2020/04/10 Python
QML用PathView实现轮播图
2020/06/03 Python
Python3读取和写入excel表格数据的示例代码
2020/06/09 Python
pycharm 关闭search everywhere的解决操作
2021/01/15 Python
CSS3教程(4):网页边框和网页文字阴影
2009/04/02 HTML / CSS
详解CSS3的opacity属性设置透明效果的用法
2016/05/09 HTML / CSS
美国便宜的横幅和标志印刷在线:Best of Signs
2019/05/29 全球购物
乐观大学生的自我评价
2014/01/10 职场文书
应届毕业生通用的自荐书范文
2014/02/07 职场文书
研讨会主持词
2014/04/02 职场文书
社会实践先进工作者事迹材料
2014/05/06 职场文书
毕业设计论文致谢词
2015/05/14 职场文书
使用Oracle命令进行数据库备份与还原
2021/12/06 Oracle