当前位置: 首页 > 图文教程 > 网络编程 > Javascript > JavaScript学习:基础继承机制

Javascript
为调试JavaScript添加输出窗口的代码
Js 中debug方式
一些mootools的学习资源
JavaScript 精粹读书笔记(1,2)
CutePsWheel javascript libary 控制输入文本框为可使用滚轮控制的js库
数组Array进行原型prototype扩展后带来的for in遍历问题
javascript 鼠标拖动图标技术
比较搞笑的js陷阱题
js 自定义的联动下拉框
js 省地市级联选择
JavaScript 类似flash效果的立体图片浏览器
JavaScript Event学习第九章 鼠标事件
jQuery AJAX回调函数this指向问题
toString()一个会自动调用的方法
jQuery 文本框模拟下拉列表效果
关于页面被拦截的问题
javascript 解析url的search方法
一个XML格式数据转换为图表的例子
Javascript 获取链接(url)参数的方法[正则与截取字符串]
一些收集整理非常不错的JS效果代码

Javascript 中的 JavaScript学习:基础继承机制


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-10   浏览: 177 ::
收藏到网摘: n/a

最近因为学校做网站设计,所以一直在ASP上和数据库上大费苦心。
  
  我在前一个阶段是做Java程序设计的。突然接到任务并学习ASP,所以我一直都热忠并善于利用JavaScript来构架ASP程序。
  
  JavaScript的一个明显的优点就在于它可以定义和持有自己的对象。这一点好象是VBScript所无法比拟的。
  有了这一点,可以利用JavaScript进行更接近于面向对象的程序设计。也许这将使网站开发更有乐趣...
  
  但有个严重的缺点!JavaScript不支持继承机制。不象Java那样,支持extends关键字(虽然这个关键字在JavaScript中是保留字)。
  
  在微软的ASP.NET中,JavaScript才开始提供比较完善的支持。PHP语言当然也有继承机制的支持,这些都叫我垂青...
  
  不过现在我根本无法说服学校的老头子们买更好的域名空间,但是我也不想忍受ASP中无继承机制之苦,所以急中生智,也就有了一些成果!
  
  JavaScript根本不支持继承机制!这是肯定的。但是我们可以想办法做些手脚,模拟一个出来。
废话说了一堆,先来看一个例子:

  function Person()
  {
  public: // 注意这个public! 其实没有这样的用法, 这只是我的习惯. 幸好在实际应用中不会有错
  this.GetName=Person_mfGetName;

  private: // 和public一样, 这也是我的习惯
  this.m_strName="Guest";
  }










  function Person_mfGetName()
  {
  return this.m_strName;
  }

  var MyPerson=new Person();
  MyPerson.GetName();

  你可以用任何输出语句来查看结果。当然这只是第一步!
  下面是关键一步:继承!

  function Student() // Extends Class: Person
  {
  EXTENDS: // 我的习惯, 但要切记不能使用小写字母. 因为extends是JavaScript中的保留字
  this.Super=Person; // 定义指向其"父类构造器". 这里的Super也不能用小写形式
  this.Super(); // 调用其"父类构造器". 这样就可以从"父类"那里"继承"所有的属性和方法

  private:
  this.m_nStudentID=0;
  }

  虽然在Student中并没有看到GetName()方法,但是却可以调用。因为他已经继承了Person的GetName()方法。

  var MyStudent=new Student();
  MyStudent.GetName(); // 注意, 调用的是其"父类"的GetName方法, 结果为返回 "Guest".


  关于JavaScript继承实现就是这样。只要牢记两步:
  
  1: 在"子类"中先定义一个指向"父类"的函数(什么名字都可以,我习惯使用Super)
  2: 随后调用这个函数
  
  这样就可以继承"父类"的所有属性和方法!
  
  我现在有些怀疑的是,既然extends和super都是保留字,那为什么JavaScript却不支持继承呢?
  不知道有没有其他更好的办法?希望各位指点...