聊一聊JS中的prototype


Posted in Javascript onSeptember 29, 2016

什么是prototype:

function定义的对象有一个prototype属性,prototype属性又指向了一个prototype对象,注意prototype属性与prototype对象是两个不同的东西,要注意区别。在prototype对象中又有一个constructor属性,这个constructor属性同样指向一个constructor对象,而这个constructor对象恰恰就是这个function函数本身。

//判断是否是数组
function isArray(obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
};
//判断是否是function
function isFunc(obj) {
return Object.prototype.toString.call(obj) === '[object Function]';
}
// 是否是json对象
function isJson(obj) {
return typeof (obj) == "object" && (isArray(obj) || Object.prototype.toString.call(obj).toLowerCase() == "[object object]");
}

对于这个属性我的理解就是继承原型对象的方法和属性。属性和方法是什么?可能一些新人不是很了解,打个比方,自行车的属性有:外表红色,可变速,可照明等,属性就是对象是什么?方法有骑自行车去上学等,方法就是对象能干什么?

那么下面我就从含义到应用说说对她的理解吧,不足之处还请大牛指点。

prototype是什么含义呢?

javascript中prototype属性:返回对象类型原型的引用。

举个例子,

A.prototype = new B()

A的prototype是B的一个实例,也就是说A讲B中的方法和属性都克隆来了一遍。注意这里是克隆而不是继承,至于克隆和继承的区别,感兴趣的同学可以自己去问下度娘。

下面上个我做的简单实例:

html部分:

<body>
<a class="btn btn1">按钮1</a>
<a class="btn btn2">按钮2</a>
<a class="btn btn3">按钮3</a>
</body>

js部分:

(function(){
var btn1 = $(".btn1");
var btn2 = $(".btn2");
var btn3 = $(".btn3");
function baseClass(){
this.showMsg = function(){
alert('11111');
}
}
function extendClass(){
this.showMsg = function(){
alert('2222');
}
}
//prototype属性可以返回对象类型的原型的引用
//如果构造函数与原型函数有同名方法,那么优先搜索构造函数的方法,不会再次克隆原型函数的同名函数
extendClass.prototype = new baseClass();
var initance = new extendClass();
btn1.click(function(){
initance.showMsg();
});
var baseinitance = new baseClass();
btn2.click(function(){
baseinitance.showMsg.call(initance);
})
})();

 理解以上实例,基本你可以初步对js中的prototype属性有个大致的认识。

以上所述是小编给大家介绍的JS中的prototype,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript使用prototype定义对象类型(转)[
Dec 22 Javascript
javascript 设为首页与加入收藏兼容多浏览器代码
Jan 11 Javascript
将数字转换成大写的人民币表达式的js函数
Sep 21 Javascript
js数值计算时使用parseInt进行数据类型转换(jquery)
Oct 07 Javascript
javascript判断变量是否有值的方法
Apr 20 Javascript
AngularJS 面试题集锦
Sep 06 Javascript
AngularJS实现给动态生成的元素绑定事件的方法
Dec 14 Javascript
js获取地址栏参数的两种方法
Jun 27 Javascript
微信小程序实现拖拽 image 触摸事件监听的实例
Aug 17 Javascript
200行代码实现blockchain 区块链实例详解
Mar 14 Javascript
CountUp.js数字滚动插件使用方法详解
Oct 17 Javascript
jquery实现简单每周轮换的日历
Sep 10 jQuery
jQuery模拟Marquee实现无缝滚动效果完整实例
Sep 29 #Javascript
jquery对Json的各种遍历方法总结(必看篇)
Sep 29 #Javascript
浅析Javascript的自动分号插入(ASI)机制
Sep 29 #Javascript
完美解决IE9浏览器出现的对象未定义问题
Sep 29 #Javascript
JSON 对象未定义错误的解决方法
Sep 29 #Javascript
Node.js检测端口(port)是否被占用的简单示例
Sep 29 #Javascript
json定义及jquery操作json的方法
Sep 29 #Javascript
You might like
php面向对象全攻略 (十五) 多态的应用
2009/09/30 PHP
php flv视频时间获取函数
2010/06/29 PHP
php中批量修改文件后缀名的函数代码
2011/10/23 PHP
thinkphp实现图片上传功能分享
2014/03/04 PHP
PHP生成不重复随机数的方法汇总
2014/11/19 PHP
thinkphp整合微信支付代码分享
2016/11/24 PHP
完美解决php 导出excle的.csv格式的数据时乱码问题
2017/02/18 PHP
在UpdatePanel内jquery easyui效果失效的解决方法
2010/04/11 Javascript
JS去掉第一个字符和最后一个字符的实现代码
2014/02/20 Javascript
jQuery中slice()方法用法实例
2015/01/07 Javascript
实例讲解Jquery中隐藏hide、显示show、切换toggle的用法
2016/05/13 Javascript
AngularJs学习第五篇从Controller控制器谈谈$scope作用域
2016/06/08 Javascript
jQuery鼠标事件总结
2016/10/13 Javascript
js 转义字符及URI编码详解
2017/02/28 Javascript
layer实现关闭弹出层刷新父界面功能详解
2017/11/15 Javascript
用Object.prototype.toString.call(obj)检测对象类型原因分析
2018/10/11 Javascript
解决vue 单文件组件中样式加载问题
2019/04/24 Javascript
vue实现点击按钮下载文件功能
2019/10/11 Javascript
微信小程序可滑动月日历组件使用详解
2019/10/21 Javascript
Vue中用JSON实现刷新界面不影响倒计时
2020/10/26 Javascript
[01:08]DOTA2次级职业联赛 - Wings 战队宣传片
2014/12/01 DOTA
用python分割TXT文件成4K的TXT文件
2009/05/23 Python
Python continue语句用法实例
2014/03/11 Python
在Python中进行自动化单元测试的教程
2015/04/15 Python
在Python的Django框架中编写错误提示页面
2015/07/22 Python
Python内置函数reversed()用法分析
2018/03/20 Python
Python3.4学习笔记之 idle 清屏扩展插件用法分析
2019/03/01 Python
Python : turtle色彩控制实例详解
2020/01/19 Python
python实现在内存中读写str和二进制数据代码
2020/04/24 Python
如何用Python 加密文件
2020/09/10 Python
中国领先的专业演出票务网:永乐票务
2016/08/29 全球购物
澳大利亚领先的在线礼品网站:Gifts Australia
2020/08/15 全球购物
Yahoo-PHP面试题1
2016/07/20 面试题
大学生学习自我评价
2014/01/13 职场文书
就业导师推荐信范文
2015/03/27 职场文书
乡镇团代会开幕词
2016/03/04 职场文书