javascript 写类方式之七
、dojo.js的写类方式
dojo最新是1.3.1了,记得07年时还是0.4。文档也渐渐多了起来,用dojo的也慢慢多了。dojo还发布了core版,压缩后只有27kb。dojo中用dojo.declare方法来定义一个类。dojo.declare的源码就不贴在这里了。dojo.declare有三个参数,
参数1:类名className
参数2:继承的类superclass
参数3:构造器,方法props
单纯的定义一个类实际只需传第一,三两个参数。因为这里只讨论如何定义一个类,不讨论继承。代码如下:
代码如下:
//定义类名
var className = "Person";
//定义构造器及方法
var proto = {
constructor : function(name){this.name=name;},
getName : function(){ return this.name;},
setName : function(name){ this.name = name;}
}
//定义类Person
dojo.declare(className,null,proto);
//创建一个对象
var p = new Person("tom");
console.log(p.getName());//tom
p.setName("jack");
console.log(p.getName());//jack
//测试instanceof及p.constructor是否正确指向了Person
console.log(p instanceof Person);//true
console.log(p.constructor === Person);//true
相关推荐
-
javascript 写类方式之七
.dojo.js的写类方式 dojo最新是1.3.1了,记得07年时还是0.4.文档也渐渐多了起来,用dojo的也慢慢多了.dojo还发布了core版,压缩后只有27kb.dojo中用dojo.declare方法来定义一个类.dojo.declare的源码就不贴在这里了.dojo.declare有三个参数, 参数1:类名className 参数2:继承的类superclass 参数3:构造器,方法props 单纯的定义一个类实际只需传第一,三两个参数.因为这里只讨论如何定义一个类,不讨论继承.代
-
javascript 写类方式之十
10.mootools.js的写类方式 mootools.js的最新版本是1.2.3,这里使用的是1.2.0.mootool被设计成非常紧凑的,模块化的,面向对象的的js库.mootool中写类用Class类.Class类由Native类new出来的: 复制代码 代码如下: /* *Script: Class.js */ var Class = new Native({ name: 'Class', initialize: function(properties){ properties = p
-
javascript 写类方式之四
4.构造函数 + 原型 直接组装一个类:同一构造函数将组装出同一类型通过前面几篇得知javascript写类无非基于构造函数 和原型 .既然这样,我们写个工具函数来写类. 复制代码 代码如下: /** * $class 写类工具函数之一 * @param {Object} constructor * @param {Object} prototype */ function $class(constructor,prototype) { var c = constructor || functi
-
javascript 写类方式之六
6.Prototype.js的写类方式 复制代码 代码如下: //prototype.js中的代码 var Class = { create: function() { return function() { this.initialize.apply(this, arguments); } } } //简化后的 function Clazz() { return function(){ this.initialize.apply(this,arguments); } } 如下步骤写一个类, 复
-
javascript 写类方式之八
8.Ext.js的写类方式 这里用的是Ext core3.0,Ext中用Ext.extend来定义一个类(当然它更多用来扩展一个类),Ext整个框架各种控件如Panel,MessageBox等都是用Ext.extend方法来扩展.这里仅仅用它来定义一个最简单的类. 看Ext.extend的代码可得知,它仍然是用构造函数和原型来组装一个类. 这里只需传两个参数即可,第一个参数是根类Object,第二个是原型. 复制代码 代码如下: /** * Person类 * @param {Object} n
-
javascript 写类方式之九
9.YUI的写类方式 这里引入的是YUI 2.7.0版,只需引入yahoo.js.YUI引入了命名空间,类似于java的包.以下yahoo的工具函数包 YAHOO.namespace YAHOO.lang YAHOO.lang.hasOwnProperty YAHOO.lang.extend YAHOO.lang.augment YAHOO.log YAHOO_config and YAHOO.env YUI Module Names写类方式: 复制代码 代码如下: //定义包名 YAHOO.n
-
javascript 写类方式之五
5.用 构造函数+原型 定义一个类:同一构造函数可以定义出多个类型 复制代码 代码如下: /** * $define 写类工具函数之二 * @param {Object} constructor * @param {Object} prototype */ function $define(constructor,prototype) { var c = constructor || function(){}; var p = prototype || {}; return function()
-
javascript 写类方式之一
EMCA262规范中没有类(class)的概念,js的new只是让他看起来更像c++,java一点.这里说的写类,只是书写js代码风格而已. 1.构造函数方式 复制代码 代码如下: /** * Person类:定义一个人,有个属性name,和一个getName方法 * @param {String} name */ function Person(name) { this.name = name; this.getName = function() { return this.name; } }
-
javascript 写类方式之三
取前面两种的优点: a.用构造函数来定义类属性(字段) b.用原型方式来定义类的方法. 就有了第三种方式.这种方式貌似采用的人较多. 3.综合构造函数/原型 复制代码 代码如下: /** * Person类:定义一个人,有个属性name,和一个getName方法 * @param {String} name */ function Person(name) { this.name = name; } Person.prototype.getName = function() { return t
-
javascript 写类方式之二
2.原型方式 复制代码 代码如下: /** * Person类:定义一个人,有个属性name,和一个getName方法 */ function Person(){} Person.prototype.name = "jack"; Person.prototype.getName = function() { return this.name;} 把类的属性(字段),方法都挂在prototype上. 造几个对象测试下: 复制代码 代码如下: var p1 = new Person();
随机推荐
- Mysql 5.7.17 解压版(ZIP版)安装步骤详解
- 数据库的三级模式和两级映射介绍
- VMware中linux环境下oracle安装图文教程(一)
- 微信公众平台开发之认证"成为开发者".Net代码解析
- Python实现读取文件最后n行的方法
- 对C语言中sizeof细节的三点分析介绍
- C#结构体特性实例分析
- 卡巴最新到2009-12-21的key 地址下载有效
- 微信小程序 开发MAP(地图)实例详解
- jQuery.Form上传文件操作
- JS保留两位小数,多位小数的示例代码
- C语言中的函数指针学习笔记
- 关于Javascript加载执行优化的研究报告
- 网站排名有了中国标准 转
- PHP实现的最大正向匹配算法示例
- C语言实现opencv提取直线、轮廓及ROI实例详解
- 如何正确实现Android启动屏画面的方法(避免白屏)
- python 获取指定文件夹下所有文件名称并写入列表的实例
- Python列表list排列组合操作示例
- Java使用反射调用方法示例