- 浏览: 526429 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (740)
- css (4)
- jquery (8)
- javascript (23)
- html (0)
- uml (0)
- 设计模式 (1)
- 开发工具 (14)
- json (4)
- struts 1.x (3)
- spring (3)
- hibernate (6)
- struts 2.x (17)
- JFreechart (0)
- j2se (48)
- jsp (9)
- flex (22)
- 找工作 (1)
- 技术杂谈 (18)
- 网络编程 (5)
- io流 (1)
- ORACLE (15)
- 报表 (3)
- extjs (11)
- jpbm (2)
- swing (5)
- jspereports (3)
- sql (1)
- linux (15)
- ps (1)
- storm (4)
- hbase (8)
- li (0)
- python (1)
- hive (3)
- 机器学习 (1)
- hdfs (1)
- elasticsearch (1)
- hadoop 2.2 (5)
- hadoop (1)
最新评论
-
Tristan_S:
这个有点意思
ASM -
starryskydog:
程序修改detail band部分的样式 如内容字体大小 ...
使用jasperReport实现动态表头 -
samwong:
Good, so usefule
使用YUI Compressor压缩CSS/JS -
gc715409742:
能够告诉我怎么在web项目中使用YUI Compressor? ...
使用YUI Compressor压缩CSS/JS -
JsonTeye:
您好! 我看你的代码,我现在也在做动态报表,实现功能由用户自己 ...
使用jasperreport动态生成pdf,excel,html
---------------------- android培训、java培训、期待与您交流!----------------------
最近在看javascript的继承 有很多不明白的地方 经过大量的查阅资料
终于有了些眉目 现在我写在这里 供大家分享
首先上代码:
// JavaScript Document
Object1 = function(name,age){
this.name = name;
this.age = age;
this.println = function(){
alert("姓名是:"+this.name+",年龄是:"+this.age);
};
}
Object2 = function(){
};
Object2.prototype = new Object1("caodaoxi",23);
obj2 = new Object2();
obj2.println();
如果我们把Object2 = {};时obj2 = new Object2();这句话会报这个错误obj2不是一个构造方法
下面我来谈谈prototype这个属性的含义 不一定正确 希望大家指正
在javascript里面根本没有类这个概念 也没有方法这个概念 只有属性这个概念 继承是通过prototype这个属性实现的 prototype实际上是一个 属性包 相当于java中的map集合 形式是这样的:(key,value) 每个function都有这个属性 当我们new的时候 javascript引擎会把我们放在prototype里面的键值对放进对象中
// JavaScript Document
Object1 = function(){
this.name = "cdx";
this.age = 25;
this.println = function(){
alert("姓名是:"+this.name+",年龄是:"+this.age);
};
}
/*Object2 = function(){
};
Object2.prototype = new Object1("caodaoxi",23);
obj2 = new Object2();
obj2.println();
*/
var ob = new Object1();
/*alert(Object1.prototype.constructor.prototype.constructor);//Object1.prototype.constructor.prototype.constructor指向和Object1.prototype.constructor指向是一样的*/
Object1.prototype.name = "账";
alert(ob.name);
这里打印的是cdx 这是为什么呢 ?为什么没有打印“账”呢 这里不能不说一下 javascript对象创建及访问对象属性的过程了 首先我们定义一个类时(姑且叫它类吧)在对象创建之前已经给它附加了一个prototype属性对象这个对象默认开始时是空的
当我们去new这个对象时 javascript引擎会把这个prototype里的属性copy到对象中去 当我们去访问一个对象的属性或方法时时 会先去对象里找有没有这个属性或方法 如果没有会去prototype里去查找有没有这个属性或方法
把上面程序改为:
// JavaScript Document
Object1 = function(){
this.age = 25;
this.println = function(){
alert("姓名是:"+this.name+",年龄是:"+this.age);
};
}
/*Object2 = function(){
};
Object2.prototype = new Object1("caodaoxi",23);
obj2 = new Object2();
obj2.println();
*/
/*alert(Object1.prototype.constructor.prototype.constructor);//Object1.prototype.constructor.prototype.constructor指向和Object1.prototype.constructor指向是一样的*/
Object1.prototype.name = "账";
var ob = new Object1();
alert(ob.name);
去掉this.name="cdx"
将打印“账”
下面再来一段javascript权威指南上的一段代码吧
Circle = function(){
this.x = 0.1;
this.y = 0.2;
}
new Circle();
Circle.prototype.pi = 3.14159;
// JavaScript Document
Object1 = function(){
// this.name = "曹道喜";
this.age = 25;
this.println = function(){
alert("姓名是:"+this.name+",年龄是:"+this.age);
};
}
Object2 = function(){
};
Object2.prototype.age = 26;
Object2.prototype = new Object1();//这里类似执行这样的语句 Object2.prototype = Object1.prototype 把Object的prototype直接复制到Object1的prototype里面
//如果object2的prototype里已经有一个age属性那么object2的prototype里的age将会被object1的prototype的age给覆盖掉
object2 = new Object2();
//alert(Object2.prototype.age);//这里会打印25
//alert(object2.age);//这里会打印25 因为这时对象object2还没有age这个属性 然后javascript引擎到object2 的prototype里去找age属性
//alert(Object2.constructor);
/*
Object2.prototype = new Object1("caodaoxi",23);
obj2 = new Object2();
obj2.println();
*/
/*alert(Object1.prototype.constructor.prototype.constructor);//Object1.prototype.constructor.prototype.constructor指向和Object1.prototype.constructor指向是一样的*/
//Object1.prototype.name = "李化龙";
//var ob = new Object1();
//ob.name = "gg";//这里等于是把 object1里放进了一个name属性 而不是放进prototype里
//alert(Object1.prototype.name);//这里打印的还是李化龙
//alert(ob.name);//如果不加ob.name = "gg";打印的就是李化龙 如果加上ob.name = "gg"; 则打印gg
/*-------------------------------第二章-------------------------*/
var s = [1,2,3,4,5]
alert(s.join());//这里并没有把s = s.join();
alert(s.constructor);//还是数组
alert(s.reverse().join());
<!--StartFragment -->
<!--StartFragment -->
---------------------- android培训、java培训、期待与您交流!----------------------
发表评论
-
js原型
2012-07-25 23:00 717原型是个很微妙的东西,很多人不是很理解,理解了原型对于研 ... -
js 格式化时间日期函数
2012-02-16 18:15 1017[代码] [JavaScript]代码 ... -
javascript设计模式
2011-12-19 08:26 7312011-08-31 23:55 by 聂微东, 11285 ... -
offsetLeft,Left,clientLeft的区别
2011-12-14 11:53 752假设 obj 为某个 HTML ... -
js去除两个数组中对象的某个属性相同的元素然后合并
2011-12-11 21:42 3951var dataArray1 = new Array();va ... -
javascript 命名空间
2011-11-30 19:18 1731在我们创建一个JavaScript库时,命名空间就显 ... -
读取js压缩为gzjs格式文件
2011-11-30 09:38 867最近做的Ext项目Ext的插件都比较大,对于网页的浏览 ... -
DOM事件传播
2011-11-25 15:53 724贴代码 test1.html <div i ... -
20 种提升网页速度的技巧 .
2011-11-07 14:14 819引言 不是所有人都能够使用高速 Inte ... -
动态加载js,css
2011-11-03 15:10 929/*Javascript 动态加载*/var JsLoad ... -
动态加载js的四种方法
2011-11-03 15:08 8411、直接document.write<s ... -
ext 中的各个style
2011-10-31 14:47 1094baseCls : 所写的css将会应用到自己的组件上 ... -
JavaScript Prototype 详解
2011-10-24 17:08 852---------------------- andr ... -
JS通用表单验证函数,基于javascript正则表达式
2011-10-17 13:02 848表单的验证在实际的开发当中是件很烦琐又无趣的事情今天在做一 ... -
Javascript正则表达式详解
2011-10-17 13:00 786js正则表达式是很多js开发人员比较头疼的事情,也很多人不 ... -
精通 JS正则表达式
2011-10-17 12:59 640正则表达式可以: •测试字符串的某个模式。例如,可以对一个输入 ... -
swfupload浅析
2010-12-24 18:12 1158一、简介和示例 SWFUpload is a small J ... -
带复选框(checkbox)的树
2010-12-14 10:13 1229带复选框(checkbox)的树 <!-- start ... -
dwr处理关联对象
2010-11-19 10:31 1038<!--l version="1.0" ... -
NodeJS探索
2010-11-07 17:05 1309一、什么是NodeJS?第一眼看到这个词,估计你和我一样,以为 ...
相关推荐
javascript prototype文档
javascript Prototype 对象扩展.docx
javascript prototype原型操作笔记.docx
JavaScriptprototype的深度探索不是原型继承那么简单.pdf
NULL 博文链接:https://miyulano.iteye.com/blog/1678239
javascript的prototype原型简单介绍: prototype原型是javascript中特别重要的概念,属于必须要掌握,如果没有良好的掌握的话,进一步用好或者学好js基本是不可能的实现的事情,并且此概念稍有难度,可能对于初次接触...
之前写的一篇JavaScript 命名空间博客提到过JavaScript的函数作用域,在函数内定义的变量和函数如果不对外提供接口,那么外部将无法访问到,也就是变为私有变量和私有函数。 function Obj(){ var a=0; //私有变量
NULL 博文链接:https://butterflymacro.iteye.com/blog/1271789
Prototype javascript框架 js and ajax 的方便
JavaScript prototype(原型对象) 所有的 JavaScript 对象都会从一个 prototype(原型对象)中继承属性和方法。 在前面的章节中我们学会了如何使用对象的构造器(constructor): 实例 function Person(first, ...
主要介绍了深入理解javascript prototype的相关知识,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
一、什么是JavaScript中对象的prototype属性 JavaScript中对象的prototype属性,是用来返回对象类型原型的引用的。我们使用prototype属性提供对象的类的一组基本功能。并且对象的新实例会”继承”赋予该对象原型的...
JavaScript使用prototype定义对象类型
JavaScript中的prototype概念恰如其分地反映了这个词的内含,我们不能将其理解为C++的prototype那种预先声明的概念。 JavaScript 的所有function类型的对象都有一个prototype属性。这个prototype属性本身又是一个...
在 JavaScript 中,prototype 不但能让对象共享自己财富,而且 prototype 还有寻根问祖的天性,从而使得先辈们的遗产可以代代相传。
用过JavaScript的同学们肯定都对prototype如雷贯耳,但是这究竟是个什么东西却让初学者莫衷一是,只知道函数都会有一个prototype属性,可以为其添加函数供实例访问,其它的就不清楚了,最近看了一些 JavaScript高级...
主要介绍了JavaScript使用prototype属性实现继承操作,结合实例形式详细分析了JavaScript使用prototype属性实现继承的相关原理、实现方法与操作注意事项,需要的朋友可以参考下
JavaScript_Prototype(源代码+中文手册)