当前位置: 首页 > 图文教程 > 网络编程 > Javascript > javascript写的一个链表实现代码

Javascript
IE6下如何让PNG图片变透明
jQuery教程:制作滑动动画效果的层
JS网页特效代码:切割网页图片特殊效果
正则表达式的高级技巧8个常用的概念
Javascript教程:获取当前地址栏url
百度前端笔试面试7个试题
互联网公司招聘web前端笔试题目
JS实例代码:点击复制地址发给QQ好友
JavaScript动态改变网页图片大小
jQuery实现搜索关键字自动匹配提示方法
JS实例代码解析:以实例方式学习数组知识
Mozilla:让JavaScript脚本直接操作本地文件
JS教程:给JavaScript文件传递参数
JS教程:如何制作表单自动聚焦的网页
通过JS正则表达式实现验证邮件的代码
JQuery教程:简化JQuery
jQuery教程:14个实用的jQuery技巧
JS实例:控制非法字符输入的JS代码
JavaScript实例:mini选择器实例代码详解
JQuery教程:获取网页表单值的方法

Javascript 中的 javascript写的一个链表实现代码


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

今天在百度上看到有人问怎么用Javascript 写一个学生管理系统。个人认为没有什么实现价值。无聊练练手吧,很久没写JS了。 本来要用Array来保存数据的,没试过用JS来数据结构,就用JS来试试吧。
JS效率真的很低一个链表装1000个对象浏览器就提示运行缓慢了。
之前觉得AJAX3D挺用前景的,现在看来还没有流行就要夭折了。用delphi开发的游戏人们都觉得太慢了,何况用JS。
下面是我实现的一个链表:
复制代码 代码如下:

/*@author eric
*@mail [email protected]
*blog.csdn.net/shmilyhe
*/
<script>
function Student(no,name){
this.id=no;
this.name=name;
this.scores={chinese:0,math:0,english:0};
}
function List(){
this.head=null;
this.end=null;
this.curr=null;
}
List.prototype.add=function(o){
var tem={ob:o,next:null};
if(this.head){
this.end.next=tem;
this.end=tem;
}else{
this.head=tem;
this.end=tem;
this.curr=tem;
}
}
List.prototype.del=function(inde){
var n=this.head;
for(var i=0;i<inde;i++){
n=n.next;
}
n.next=n.next.next?n.next.next:null;
}
List.prototype.next=function(){
var te=null;
if(this.curr){
te=this.curr.ob; this.curr=this.curr.next;}
return te;
}
List.prototype.hasnext=function(){
if(this.curr.ob!=null)return true;
return false;
}
var list=new List();
for(var i=0;i<1000;i++){
list.add(new Student(i,'name'+i));
}
var i=0;
while(list.hasnext()){
document.writeln(list.next().name);
if(i==10){document.writeln('<br/>'); i=0;}
i++;
}
</script>