JS类定义原型方法的两种实现的区别评论很多


Posted in Javascript onSeptember 12, 2007

我们知道,给JavaScript类添加原形(prototype)方法是很简单的。而且常用的有下面这两种方法,可是这两种方法在使用时有区别吗? 
    JScript Class: 

 function JSClass()  
 {       
 } 

    Extends prototype method: 
 JSClass.prototype.MethodA = function()  
 {   }; 

    Or 
 
function = JSClass.prototype.MethodA()  
 {   };

# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
我先来说一个简单的区别:这两个方法导入的原型方法,第一个是一个匿名方法;第二个方法有方法名"JSClass.prototype.MethodA"。 
2005-03-01 10:52 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
<BODY> 
<script> 
function JSClass() 

function = JSClass.prototype.MethodA() 

}; 
</script> 
</BODY> 

提示出错乜。 
2005-03-01 13:51 | 阮 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
faint,我发现FreeTextBox修改少量数据(一两个字符)提交有时会没有效果:( 
我那个是手误多写了个"=",可是我记得我修改过了的。 
2005-03-01 14:00 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
     其实这两个原形定义方式可以简化一下来讨论,先把它们看作是两个函数,如下:
  Foo1(); 

  function Foo1() 
  { 
      alert('This is Foo1.'); 
  }
     和   Foo2(); 
  var Foo2 = function() 
  { 
      alert('This is Foo2.'); 
  }

     运行第一个显然是不会有任何错误的,可是运行第二个就有问题了,这时系统会说:Microsoft JScript runtime error: Object expected。这就是说函数定义(Foo1)在脚本解析器中有最高的初始化优先级,这个很好理解。如果不优先处理函数,那么对于函数中的函数调用就没有办法处理了,假使我们先定fn1()再定义fn2(),却从fn1中调fn2,那么就通不过解析了。为什么Foo2不能被初始化,Foo2的定义根本不是函数定义,它是一个标准的赋值语句,之所以能象标准函数一样的使用Foo2(Foo2()),完全是因为它指向的是一个函数对象的实例而已。

2005-03-03 22:17 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
     再来看原形方法导入里的两种方式,就很简单了。并且不同的执行优先循序,也决了它们在使用中的不同,看如下示例:
<script language="javascript">
function NormalClass() 

    this.m_Property1 = 'P1 in Normal Class.'; 
    this.m_Property2 = 'P2 in Normal Class.'; 

    this.toString = function() 
    { 
         return '[class NormalClass]'; 
    }

    return new InnerClass();   

    function InnerClass() 
    { 
         this.m_Property1 = 'P1 in Inner Class.';  
         this.m_Property2 = 'P2 in Inner Class.';  

         this.toString = function() 
         { 
              return '[class InnerClass]'; 
         }     
    }

    InnerClass.prototype.Method1 = function() 
    { 
         alert(this.m_Property1); 
    }; 

    function InnerClass.prototype.Method2() 
    { 
         alert(this.m_Property2); 
    };   
}
</script>

     执行: 
var nc = new NormalClass(); 
nc.Method1(); 
nc.Method2();

     是什么效果?为什么? 

2005-03-03 22:21 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
最后结果居然是nc.Method1()没有定义,nc.Method2()运行正常。
其实不奇怪了,InnerClass.prototype.Method1 = function()依赖于赋值语句的执行,而 function InnerClass.prototype.Method2() 以最高优先级被脚本引擎初始化。 
2005-03-05 02:43 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
我在Antechinus JavaScript Editor测试你的代码在: 

function InnerClass.prototype.Method2()报错, 

SyntaxError:missing( before formal parameters See: .prototype.Method2( 
2005-05-10 17:11 | Error 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
@Error 
用IE来试过吗? 
2005-05-10 17:30 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
我用FF也是一样的报错: missing( before formal parameters See: .prototype.Method2( 
2006-08-19 22:40 | jzz 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
return new InnerClass(); 把这行移到 
function InnerClass.prototype.Method2() 

alert(this.m_Property2); 
}; 
后面ie执行正常.FF报错: missing( before formal parameters See: .prototype.Method2( 
ie是安顺序执行下来的,而NS系列不是! 
FF在执行到function InnerClass.prototype.Method2() 这个的时候它根本不知道有这个InnerClass类,自然就不能无缘无故的来个prototype.xxx的东东 
2006-11-13 00:57 | Doutu 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
@Doutu 
把return new InnerClass();放到function InnerClass.prototype.Method2()这个方法之后,就完全违背了我编写这个示例的初衷。这个示例恰好说明了,IE对function foo()这种函数定义格式有较高的解析优先级,而foo = function()只是一个普通的赋值语句。至于ff中的情况我没有研究过,既然你说ff找不到return后的InnerClass,那么就说明是顺序的解析function foo()这种还属定义格式的。 
2006-11-13 01:29 | birdshome 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
唉。可怜的只会用ie的人呀。 function x.y.z() {} 的写法根本就是不标准的写法,只有ie支持,其他js引擎中如ff或opera都会报错。符合标准的写法只有 x.y.z = function () {};

当然,就语法层面来说,我挺喜欢这种写法的,希望以后的标准能采纳这种写法。 
2006-11-28 11:04 | hax 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
呵呵 hax说得对啊。 只有ie才会像妈妈一样包容孩子的各种错误 

标准的写法只有 x.y.z = function () {}; 

其实,ie还支持更诡异的写法。 

看看这个 
function window::onload(){ 
alert("go_rush") 

2006-11-28 14:39 | Go_Rush 
# re: JS类定义原型方法的两种实现的区别  回复  更多评论    
@hax 
标准再好,也是为人服务的,争论这个是学院派和工程派之间的事情,我们实现好我们自己系统就可以了,何必过分在神仙打架。 
// 你的评论其实挺好的。Sigh,只可惜因为IE,我好可怜啊~~~ 

Javascript 相关文章推荐
JS下高效拼装字符串的几种方法比较与测试代码
Apr 15 Javascript
js限制文本框为整数和货币的函数代码
Oct 13 Javascript
javascript查找字符串中出现最多的字符和次数的小例子
Oct 29 Javascript
jquery分页插件jpaginate在IE中不兼容问题
Apr 22 Javascript
jQuery 1.9使用$.support替代$.browser的使用方法
May 27 Javascript
JS数组的遍历方式for循环与for...in
Jul 31 Javascript
莱鸟介绍javascript onclick事件
Jan 06 Javascript
JS刷新父窗口的几种方式小结(推荐)
Nov 09 Javascript
谈谈JavaScript数组常用方法总结
Jan 24 Javascript
详解如何在 vue 项目里正确地引用 jquery 和 jquery-ui的插件
Jun 01 jQuery
详解React native全局变量的使用(跨组件的通信)
Sep 07 Javascript
WebSocket的简单介绍及应用
May 23 Javascript
js类中获取外部函数名的方法与代码
Sep 12 #Javascript
javascript下过滤数组重复值的代码
Sep 10 #Javascript
“不能执行已释放的Script代码”错误的原因及解决办法
Sep 09 #Javascript
超强的IE背景图片闪烁(抖动)的解决办法
Sep 09 #Javascript
IE不出现Flash激活框的小发现的js实现方法
Sep 07 #Javascript
用javascript实现画板的代码
Sep 05 #Javascript
js中的escape及unescape函数的php实现代码
Sep 04 #Javascript
You might like
了解Joomla 这款来自国外的php网站管理系统
2010/03/11 PHP
php实现使用正则将文本中的网址转换成链接标签
2014/12/03 PHP
PHP弹出对话框技巧详细解读
2015/09/26 PHP
php array_values 返回数组的所有值详解及实例
2016/11/12 PHP
Ecshop 后台添加新功能栏目及管理权限设置教程
2017/11/21 PHP
laravel validate 设置为中文的例子(验证提示为中文)
2019/09/29 PHP
Gambit vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
Dom 是什么的详细说明
2010/10/25 Javascript
JavaScript中的方法重载实例
2015/03/16 Javascript
jQuery中 attr() 方法使用小结
2015/05/03 Javascript
JavaScript实现点击按钮切换网页背景色的方法
2015/10/17 Javascript
Jquery1.9.1源码分析系列(十五)动画处理之外篇
2015/12/04 Javascript
javascript实现拖放效果
2015/12/16 Javascript
基于JS代码实现图片在页面中旋转效果
2016/06/16 Javascript
JS实现输入框提示文字点击时消失效果
2016/07/19 Javascript
打造自己的jQuery插件入门教程
2016/09/23 Javascript
javascript工厂模式和构造函数模式创建对象方法解析
2016/12/30 Javascript
深入理解Webpack 中路径的配置
2017/06/17 Javascript
jQuery Form插件使用详解_动力节点Java学院整理
2017/07/17 jQuery
layer实现关闭弹出层刷新父界面功能详解
2017/11/15 Javascript
Vue实现带进度条的文件拖动上传功能
2018/02/23 Javascript
Vue下拉框回显并默认选中随机问题
2018/09/06 Javascript
使用layui实现树形结构的方法
2019/09/20 Javascript
微信小程序使用自定义组件导航实现当前页面高亮
2020/01/02 Javascript
Vue的el-scrollbar实现自定义滚动
2018/05/29 Python
python实现梯度下降算法
2020/03/24 Python
Pandas删除数据的几种情况(小结)
2019/06/21 Python
Python3如何在Windows和Linux上打包
2020/02/25 Python
python3爬虫中异步协程的用法
2020/07/10 Python
OpenCV+Python3.5 简易手势识别的实现
2020/12/21 Python
Python从MySQL数据库中面抽取试题,生成试卷
2021/01/14 Python
便利店投资的创业计划书
2014/01/12 职场文书
婚纱店策划方案
2014/05/22 职场文书
员工工作能力评语
2014/12/31 职场文书
大学生个人年度总结范文
2015/02/15 职场文书
暑期社会实践个人总结
2015/03/06 职场文书