爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JavaSript
Javascript种,prototype研究
Javascript种,prototype研究
日期:2014-05-16 浏览次数:20477 次
Javascript类,prototype研究。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>测试Javascript类</title> </head> <body> <div id="dbg"> </div> <script type="text/javascript"> function p(str) { if(str.indexOf('err')!=-1) str = '<font color="#ff0000">'+str+'</font>'; str = str.replace(/(pro_fun)/g,'<font color="#ff00ff">$1</font>'); str = str.replace(/(pub_fun)/g,'<font color="#0000ff">$1</font>'); g('dbg').innerHTML = g('dbg').innerHTML+'<br />'+str; } function g(id) { return document.getElementById(id); } function f1() { var pri_var = 'pri_var'; this.pub_var = 'pub_var'; this.pub_fun = function() { try{ p('pub_fun->pri_var:'+pri_var); }catch(e){ p('pub_fun->pri_var(err):'+e); } try{ p('pub_fun->pub_var:'+this.pub_var); }catch(e){ p('pub_fun->pub_var(err):'+e); } //--------------------------------------------- try{ p('pub_fun->pro_var:'+this.pro_var); }catch(e){ p('pub_fun->pro_var(err):'+e); } //--------------------------------------------- try{ this.pro_fun(); }catch(e){ p('cls.pub_fun->pro_fun(err):'+e); } } this.pub_chgv=function(){//注意下面有一个f1.prototype.pub_chgv,而被认可的是这个函数,ie9 ff this.pub_var = 'pub_var->pub_chgv'; this.pro_var = 'pro_var->pub_chgv'; p('pub_chgv->pub_var: '+this.pub_var); p('pub_chgv->pro_var: '+this.pro_var); } } f1.prototype.pro_var = 'pro_var'; f1.prototype.pro_fun = function(){ try{ p('pro_fun->pri_var:'+pri_var); }catch(e){ p('pro_fun->pri_var(err):'+e); } try{ p('pro_fun->pri_var:'+this.pri_var); }catch(e){ p('pro_fun->pri_var(err):'+e); } try{ p('pro_fun->pub_var:'+this.pub_var); }catch(e){ p('pro_fun->pub_var(err):'+e); } //--------------------------------------------- try{ p('pro_fun->pro_var:'+this.pro_var); }catch(e){ p('pro_fun->pro_var(err):'+e); } } f1.prototype.pub_chgv=function(){ this.pub_var = 'pub_var->pro_chgv'; this.pro_var = 'pro_var->pro_chgv'; p('pro_chgv->pub_var: '+this.pub_var); p('pro_chgv->pro_var: '+this.pro_var); } f1.prototype.pro_getv=function(){ p('<hr>pro_getv->pub_var: '+this.pub_var); p('pro_getv->pro_var: '+this.pro_var); p('pro_getv->pro_var: '+f1.pro_var+' <-- 这说明:将prototype增加的属性或者方法称为静态的方法或者属性并不正确,因为它不能不实例化直接调用'); } var CLA = new f1(); var clb = new f1(); CLA.pub_fun(); try{ f1.pro_getv(); }catch(e){ p('f1.pro_getv(err):'+e+' <-- 这说明:将prototype增加的属性或者方法称为静态的方法或者属性并不正确,因为它不能不实例化直接调用'); } //一个实例改变私有变量或者prototype变量,不会影响其它的实例的值(改变自己的prototype属性会复制一份给自己,根据作用于原理(从自身向上查),自己有一个复制之后,就不再受prototype影响) CLA.pub_chgv(); clb.pro_getv(); //--------------------------------------------- //一个实例改变增加或者改变方法属性,都不会影响其它实例 CLA.pro_getv=function(){ p('<hr><font color="#00ffff">new by instance</font> pro_getv->pub_var: '+this.pub_var); p('<font color="#00ffff">new by instance</font> pro_getv->pro_var: '+this.pro_var+' <--- 注意pro_var在前面通过CLA.pub_chgv()改变了值,它就不再是引用prototype的值了,因此它不受prototype的影响了'); p('<font color="#00ffff">new by instance</font> pro_getv->pro_var: '+f1.pro_var); } clb.pro_getv(); //--------------------------------------------- //通过原始类的.prototype去改变属性或者方法,会使所有的未通过实例自身改变属性或者方法的实例的也变化 f1.prototype.pro_var = 'pro_var changed'; f1.prototype.pro_getv=function(){ p('<hr>new 1 pro_getv->pub_var: '+this.pub_var); p('new 1 pro_getv->pro_var: '+this.pro_var); p('new 1 pro_getv->pro_var: '+f1.pro_var); } clb.pro_getv(); //CLA 通过实例自身改变过pro_g
上一篇: ssh如何知道删除实体成不成功
下一篇: 办好5个javascript细节,别让人看出你很烂
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
jquery获取ul li上面a标签的一个值,要想些监听a标签的事件
Javascript 验证下传图片大小[客户端]
javascript回定义类的规范小结
请梅花雪过来看,还是关于怎么判断window.parent.opener是否关闭的有关问题!
EXTJS制造一个简单表格的思路
揭开Javascript闭包的真实面容
jsf+spring+hibernate有关问题,启动tomcat后报错
JS读取XML并展示各节点[兼容IE/FF/Chrome,Safari]
jstl中的判断list中是不是包含某个值
推荐阅读
更多>
extjs的dwrStore有关问题
js中 innerHTML的有关问题,求大神解决,
javascript权威指南的1点总结
使用jquery写了一个点击按钮后在页面输出结果的程序,能用AJAX让页面不刷新吗?解决方法
如果获得一个div的宽高,该怎么处理
Think in AngularJS:对照jQuery和AngularJS的不同思维模式
JS中substr跟substring的区别
最近要做的一个关于JS (node.js)的技术交流,发一上提纲,欢迎大家帮忙完善
jQuery链式语法 用js生成页面 而且响应click事件
ExtJs2 panel控件居中有关问题
JS(this跟执行上下文)
smipleChart 容易图表类 javascript
javascript 传入的数组 怎么 打印 出他得值,而不是地址?
jsp页面,contentType中的charset跟pageEncoding的区别
Javascript Label话语的应用
JSEclipse插件装配
新手加入JS军团!混个脸熟!以后有关问题还请们多多帮忙
求 radio + text 的显示与隐藏的有关问题
Extjs 4.0.6 如果有,给一个。200分。解决方案
编纂高质量代码:改善JavaScript程序的188个建议