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

Javascript
javascript下操作css的float属性的特殊写法
javascript之DIV拖动类 支持在FF下拖动,调用简单
Expandable "Detail" Table Rows
用javascript实现给出的盒子的序列是否可连为一矩型
PNGHandler-借助JS让PNG图在IE下实现透明(包括背景图)
JS创建优美的页面滑动块效果 - Glider.js
发一个比较漂亮的选项卡动态增删的效果
可多次使用的仿126邮箱选项卡的源码
javascript仿XP关机效果的弹出窗口功能
JS控制CSS样式的方法
非常漂亮的JS代码经典广告
推荐自用 Javascript 缩图函数 (onDOMLoaded)……
几个不错的自动收缩菜单导航效果
iframe src为图片时的高度自适应的代码
论坛转贴工具中用到的正则表达式学习正则的好例子
用javascript实现的不错的一款网页选项卡
摘自百度的图片轮换效果代码
用javascript实现旋转图片效果的代码
javascript 制作坦克大战游戏初步 图片与代码
比较简单的jquery教程 Easy Ajax with jQuery 中文版全集

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 124 ::
收藏到网摘: 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却不支持继承呢?
  不知道有没有其他更好的办法?希望各位指点...