JS中的prototype的含义
2015-10-20 18:09
597 查看
我们知道JScript中对象的prototype属性,是用来返回对象类型原型的引用的。我们使用prototype属性提供对象的类的一组基本功能。并且对象的新实例会"继承"赋予该对象原型的操作。但是这个prototype到底是怎么实现和被管理的呢?
对于对象的prototype属性的说明,JScript手册上如是说:所有 JScript 内部对象都有只读的 prototype 属性。可以向其原型中动态添加功能(属性和方法),但该对象不能被赋予不同的原型。然而,用户定义的对象可以被赋给新的原型。
下面我们看三个经典的prototype属性的使用示例。
1、为脚本环境内建对象添加方法:
程序代码
Array.prototype.max = function()
{
var i, max = this[0];
for (i = 1; i < this.length; i++)
{
if (max < this[i])
max = this[i];
}
return max;
};
2、为用户自定义类添加方法:
程序代码
function TestObject(name)
{
this.m_Name = name;
}
TestObject.prototype.ShowName = function()
{
alert(this.m_Name);
};
3、更新自定义类的prototype:
程序代码
function TestObjectA()
{
this.MethodA = function()
{
alert('TestObjectA.MethodA()'); //显示这一段文字而已
}
}
function TestObjectB()
{
this.MethodB = function()
{
alert('TestObjectB.MethodB()');
}
}
TestObjectB.prototype = new TestObjectA();
对于对象的prototype属性的说明,JScript手册上如是说:所有 JScript 内部对象都有只读的 prototype 属性。可以向其原型中动态添加功能(属性和方法),但该对象不能被赋予不同的原型。然而,用户定义的对象可以被赋给新的原型。
下面我们看三个经典的prototype属性的使用示例。
1、为脚本环境内建对象添加方法:
程序代码
Array.prototype.max = function()
{
var i, max = this[0];
for (i = 1; i < this.length; i++)
{
if (max < this[i])
max = this[i];
}
return max;
};
2、为用户自定义类添加方法:
程序代码
function TestObject(name)
{
this.m_Name = name;
}
TestObject.prototype.ShowName = function()
{
alert(this.m_Name);
};
3、更新自定义类的prototype:
程序代码
function TestObjectA()
{
this.MethodA = function()
{
alert('TestObjectA.MethodA()'); //显示这一段文字而已
}
}
function TestObjectB()
{
this.MethodB = function()
{
alert('TestObjectB.MethodB()');
}
}
TestObjectB.prototype = new TestObjectA();
相关文章推荐
- jsoup:解析HTML用法小结
- javascript对象的属性,方法,prototype作用范围分析
- JavaScript实现 页面滚动图片加载
- jsp国际化文件编码转换
- 作用域(1)---Js作用域链及变量作用域
- 常用JS
- 使用pdf.js显示pdf文件
- 【bzoj1821】 JSOI2010Group 部落划分 二分+并查集
- 深入解析JavaScript的闭包机制
- 【学习笔记javascript设计模式与开发实践(单例模式)----4】
- Javascript中的数据类型之旅
- JavaScript 核心参考教程 内置对象
- 了解 JavaScript 中的内置对象
- javascript面向对象方式,调用属性和方法
- w3school js 测验
- JavaScript知识(一直更新)
- JavaScript基本的输出和嵌入式写法教程
- js编写快速排序
- 类(2)---Javascript定义类(class)的三种方法
- 自己寫的 Loading JS插件