- 浏览: 886633 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (687)
- java (127)
- servlet (38)
- struts (16)
- spring (22)
- hibernate (40)
- javascript (58)
- jquery (18)
- tomcat (51)
- 设计模式 (6)
- EJB (13)
- jsp (3)
- oracle (29)
- RUP (2)
- ajax (3)
- java内存管理 (4)
- java线程 (12)
- socket (13)
- path (5)
- XML (10)
- swing (2)
- UML (1)
- JBPM (2)
- 开发笔记 (45)
- Note参考 (15)
- JAXB (4)
- Quartz (2)
- 乱码 (2)
- CSS (2)
- Exception (4)
- Tools (7)
- sqlserver (3)
- DWR (7)
- Struts2 (47)
- WebService (2)
- 问题解决收藏 (7)
- JBOSS (7)
- cache (10)
- easyUI (19)
- jQuery Plugin (11)
- FreeMarker (6)
- Eclipse (2)
- Compass (2)
- JPA (1)
- WebLogic (1)
- powerdesigner (1)
- mybatis (1)
最新评论
-
bugyun:
受教了,谢谢
java 正则表达式 过滤html标签 -
xiongxingxing_123:
学习了,感谢了
java 正则表达式 过滤html标签 -
wanmeinange:
那如果无状态的。对同一个任务并发控制怎么做?比如继承Quart ...
quartz中参数misfireThreshold的详解 -
fanjieshanghai:
...
XPath 元素及属性查找 -
tianhandigeng:
还是没明白
quartz中参数misfireThreshold的详解
一说到prototype
很多人可能第一个想到的是著名的prototype.js框架,当然我们今天说的不是它,而是Javascript中的prototype
属性,一般都被翻译为“原型”。这是一个比较特殊的属性,Javascript中的继承一般都依赖这属性实现。
在Javascript中,一切都是对象,字符串是对象,数组是对象,变量是对象,函数也是对象,所以才会允许['a','b','c'].push('d');
这样的操作存在。类本身也是一个对象,也可以定义属性和方法:
- function Test(){};
- Test.str = 'str';
- Test.fun = function(){return 'fun';};
- var r1 = Test.str; // str
- var r2 = Test.fun(); // fun
- var inst = new Test();
- var r3 = inst.str; // undefined
- var r4 = inst.fun(); // undefined
prototype
就是一个作用于类的属性。默认情况下,所有Javascript类都会有一个prototype
属性,但是类实例没有。
- function Test(){};
- var p1 = typeof(String.prototype); // object
- var p2 = typeof(Test.prototype); // object
- var p3 = typeof(new Test().prototype); // undefined
- var p4 = typeof(Object.prototype); // object
- var p5 = typeof(new Object().prototype); // undefined
取值与赋值
在Javascript中,当我们取一个对象中并不存在的属性或是方法时,它会试图查看该对象所对应的类中的prototype
属性中是否包含该属性或是方法,而prototype
也是一个Javascript对象,若是其中也没有,该prototype
又会访问它对应的类的prototype
,如此一级级地向上访问,直到找到需要的属性或方法,或是prototype
属性为null。
- function Test(){};
- Test.test = 'str';
- function pt1()
- { this.test1 = 'pt1'; };
- function pt2()
- { this.test2 = 'pt2'; };
- pt2.prototype.test3 = 'test3';
- pt2.prototype.test1 = 'test4';
- pt1.prototype = new pt2();
- Test.prototype = new pt1();
- var inst = new Test();
- var p1 = inst.test; // undefined
- var p2 = inst.test1; // pt1 而不是 test4
- var p3 = inst.test2; // pt2
- var p4 = inst.test3; // test3
相对于取值,赋值就简单得多了。它并不会一层层向上查找prototype
中的属性值,而直接对当前的实例进行赋值,没有则创建。
内置类的增强
在Javascript中并不能直接修改内置类的prototype
。但是可以通过修改prototype
的属性达到修改内置类行为的目的。
- Array.prototype = {push:function(){alert('test1');}}; // 不起作用
- Array.prototype.push = function(){alert('test2');}; // 可以
- var test = new Array('a','b','c');
- test.push('d'); // test2
一次可以插入多个元素的Array.push
函数:
- Array.prototype.pushs = function()
- {
- var pos = this.length;
- for(var i=0; i<arguments.length; i++)
- {
- this[++pos] = arguments[i];
- }
- return this.length;
- }
- var test = new Array('a','b','c');
- test.pushs('d','e');
值得注意的是,为内置类的prototype
添加的函数,在使用for
语句输出属性时,也会被显示:
- var str;
- for(var i in test)
- {
- str += (' ' + i); // '0 1 2 3 4 5 pushs' pushs自定义函数。
- }
但是可以通过hasOwnProperty()
进行判断:
- var str;
- for(var i in test)
- {
- if(test.hasOwnProperty(i)) // 过滤掉pushs函数。
- { str += (' ' + i); }
- }
一点点注意事项
前面说过,prototype
是类的一个属性。更改prototype
中的属性值,有可能会带来意想不到的灾难!
- function Test(){}
- Test.prototype.num = 3;
- var inst1 = new Test();
- var inst2 = new Test();
- Test.prototype.num = 4; // 所有指向Test.prototype.num的值。
- var p1 = inst1.num; // 4
- var p2 = inst2.num; // 4
- inst1.num = 5; // 赋值,会为inst对象创建一个num属性。
- Test.prototype.num = 6; // 所有指向Test.prototype.num的值。
- var p3 = inst1.num; // 5 这里返回的是刚创建的inst1.num的值,而不是Test.prototype.num的值。
- var p4 = inst2.num; // 6
- delete Test.prototype.num;
- var p5 = inst1.num; // 5 inst1.num依然存在。
- var p6 = inst2.num; // undefined Test.prototype.num 被删除了。
发表评论
-
HTML特殊字符显示
2011-08-16 21:45 1005有些字符在HTML里有特别的含义,比如小于号<就表示HT ... -
html标签a的target属性的用法
2011-08-02 00:40 10871:如果使用标签<a>来链接到一个页面的话,tar ... -
JavaScript中的函数:函数的apply、call方法和length属性
2011-06-03 13:39 818转:http://www.smallrain.net/stud ... -
JS arguments 属性
2011-06-03 13:38 901arguments 属性 为当前执行的 function 对象 ... -
JS数组方法汇总
2011-03-31 12:18 1038js数组元素的添加和删除一直比较迷惑,抽个时间总结如下:var ... -
选择,分组和引用
2011-03-17 12:59 817正则表达式的语法还包 ... -
javascript 中定义private 方法
2011-03-15 09:49 953出处:http://aoqi1883.blog.163.com ... -
event.returnValue和return false的区别
2011-03-15 09:48 1235<!DOCTYPE html PUBLIC " ... -
JavaScript--execCommand指令集
2011-03-15 09:23 964<HTML> <HEAD> ... -
个性博客-七款超靓天气预报免费代码
2011-03-15 09:12 1012第一种: <iframe src="http: ... -
js判断对象是否是某一类型
2011-03-15 09:05 946<!DOCTYPE html PUBLIC " ... -
常用的DOCUMENT.EXECCOMMAND
2011-03-15 09:04 1043<input type=button value=剪切 ... -
解决IE6中 Div层挡不住Select组件
2011-03-14 09:39 1098/** * 通过使用Ifram,解 ... -
配置文件(fckconfig.js)中主要配置项目如下
2011-02-18 10:59 886FCKConfig.CustomConfigurationsP ... -
[转]疯狂的跨域技术
2011-01-30 15:36 1074JavaScript是一种在Web开发中经常使用的前端动态脚本 ... -
JAVASCRIPT中RegExp.$1是什么意思
2011-01-28 15:02 2194RegExp 是javascript中的一个内置对象。为正则表 ... -
js监听WEB页面关闭事件
2010-12-31 10:54 6393javascript捕获窗口关闭事件有两种方法 onbefor ... -
天气数据调用代码,总结了一下收藏
2010-12-14 12:41 1100转载于:http://blog.csdn.net/ ... -
自动跳转
2010-12-13 15:43 929<meta http-equiv="refre ... -
JavaScript面向对象编程
2010-12-07 23:27 892创建自己的对象 要创 ...
相关推荐
在JavaScript中,遍历属性、理解`prototype`和掌握...总结,遍历JavaScript对象的属性有多种方法,而`prototype`和继承机制是实现面向对象编程的关键。理解并熟练运用这些概念,将有助于编写更高效、更可维护的代码。
总结起来,JavaScript的`prototype`属性是用来实现对象的继承和共享方法的关键机制。通过在构造函数的`prototype`上定义方法,可以避免每个实例都存储一份相同方法的副本,从而提高内存效率。理解并掌握`prototype`...
JavaScript中的...总结,JavaScript中的prototype属性是实现面向对象编程的重要组成部分,它涉及到继承、方法共享以及原型链等核心概念。理解并熟练运用这些知识,能够帮助开发者构建更复杂、更高效的应用程序。
总结来说,`prototype`是JavaScript中的重要特性,它提供了对象继承和方法共享的能力。通过理解和熟练运用`prototype`,开发者可以编写出更加高效和可维护的代码。而这个"非常有用的prototype实例"提供了实践和学习`...
总结而言,本文向我们解释了JavaScript中的prototype属性,揭示了其作为函数属性的特性,并且指导我们如何通过实验和例子来更准确地理解和掌握这一概念。这对于我们这些学习JavaScript面向对象编程的人来说,是非常...
1. **函数的prototype属性** 当我们创建一个函数时,如`function Person() {}`,`Person.prototype`就是一个对象,可以添加方法和属性。这些方法和属性可以被通过`new Person()`创建的对象共享。 2. **构造函数与...
总结一下,Prototype通过其丰富的Ajax接口,使得开发者能够更加便捷地处理异步请求。无论是简单的GET请求、更新页面内容,还是处理表单提交,Prototype都提供了优雅的解决方案。通过实践和理解Prototype中的Ajax功能...
《Prototype 1.5.1使用手册》是针对JavaScript库Prototype的一个详细指南,该库是Web开发中的一个强大工具,尤其在处理DOM操作、Ajax交互和函数增强方面表现卓越。本手册以.chm(Compiled Help Manual)格式提供,...
总结来说,`prototype`属性在JavaScript中扮演着核心角色,它是实现面向对象编程和原型继承的关键。理解并熟练运用`prototype`可以帮助我们更有效地编写和优化代码。在实际开发中,我们常常会利用`prototype`来扩展...
- **`Object.prototype.extend`**:该方法使得任何对象都可以直接使用 `extend` 方法来自身扩展其他对象的属性。这是一种链式调用的方式,使得代码更加灵活。 #### 6. Function.prototype.bind 方法 ```javascript...
总结一下,`prototype`在JavaScript中扮演着关键的角色,它是实现面向对象编程和继承的核心机制。通过理解和熟练使用`prototype`,我们可以创建出更加复杂且可复用的代码结构。同时,了解`__proto__`、`constructor`...
总结一下,`instanceof`和`prototype`在JavaScript中分别用于检测对象实例和定义对象的继承结构。`instanceof`通过查找对象的原型链来确定对象与构造函数之间的实例关系,而`prototype`则用来设置和访问对象的原型...
JavaScript中的`prototype`是理解面向...总结,`prototype`在JavaScript中起着核心作用,它是实现面向对象编程的重要一环。理解`prototype`以及相关的原型链、继承和对象创建方式,对于深入学习JavaScript至关重要。
本文将详细探讨 Prototype 1.7.2 版本的特点和关键知识点,通过源码解析,帮助开发者更好地理解和应用这一框架。 1. **核心特性** Prototype 的核心特性包括增强的 JavaScript 对象模型、强大的 DOM 操作接口和...
总结来说,constructor 属性和 prototype 属性在 JavaScript 中非常关键,它们共同构成了 JavaScript 原型继承的基础。理解这两个属性的工作原理对于掌握 JavaScript 面向对象编程及其继承机制至关重要。
2. **只有Function有prototype属性**:这是事实,但需要注意的是,这个`prototype`属性并不是Function对象自身的原型,而是当这个Function用作构造函数时,新创建的对象将继承的原型。例如,当我们创建一个新实例`...
### JavaScript面向对象之共享成员属性与方法及prototype关键字用法 #### 一、概述 JavaScript是一种基于原型的语言,它支持面向对象编程(OOP),但在实现上与其他语言有所不同。本篇文章将深入探讨JavaScript中...
总结起来,`prototype`是JavaScript实现继承和共享属性的关键机制。通过理解和巧妙地运用`prototype`,我们可以构建出更加灵活和高效的代码结构。在压缩包`myJs`中,可能包含了实现上述概念的示例代码,通过分析和...