本文实例讲述了JS表的模拟方法。分享给大家供大家参考。具体方法如下:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>列表</title> <script> function List(){ this.listSize= 0; this.pos=0; this.dataStore=[];//初始化一个空数组来保存列表元素 this.clear =clear; this.find = find; this.toString= toString; this.insert = insert; this.append= append; this.remove =remove; this.front = front; this.end = end; this.prev =prev; this.next = next; this.length= length; this.currPos= currPos; this.moveTo= moveTo; this.getElement =getElement; this.length = length; this.contains = contains; function append(element){ this.dataStore[this.listSize++] = element; }; function find(element){ for(var i =0; i<this.dataStore.length; i++){ if(this.dataStore[i]===element){ return i ; } } return -1; } function remove(element){ var foundAt =this.find(element); if(foundAt!=-1){ this.dataStore.splice(foundAt,1); this.listSize--; return element; //return true 原本是这样,后面本人改为ELEMENT }else{ return false; } } function length(){ return this.listSize; } function toString(){ return this.dataStore; } function insert(element,after){ var insertPos = this.find(after); if(insertPos!=-1){ this.dataStore.splice(insertPos+1,0,element); this.listSize++; return true; }else{ return false; } } function clear (){ delete this.dataStore; this.listSize=0; this.pos=0; this.dataStore=[]; } function contains(element){ for(var i =0; i<this.dataStore.length; i++){ if(this.dataStore[i]===element){ return true ; } } return false; } function front(){ this.pos = 0; } function end(){ this.pos = this.listSize-1; } function prev(){ // if(this.pos> 0){ --this.pos; // } } function next(){ // if(this.pos< this.listSize-1){ ++this.pos; // } } function currPos(){ return this.pos; } function moveTo(pos){ this.pos= pos; } function getElement(){ return this.dataStore[this.pos]; } } var list = new List(); list.append({name:'夏广成',sex:'男'}); list.append({name:'江荣盛',sex:'男'}); list.append({name:'杜强',sex:'男'}); list.append({name:'巧华',sex:'女'}); list.append({name:'方阳',sex:'男'}); for(list.front(); list.currPos() < list.length() ; list.next()){ var item = list.getElement(); if(item.sex =='女'){ list.remove(item); } } for(list.front(); list.currPos() < list.length() ; list.next()){ var item = list.getElement(); console.log(item.name); } </script> </head> <body > </body> </html>
希望本文所述对大家的javascript程序设计有所帮助。
标签:
JS,表,模拟,方法
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“JS表的模拟方法”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2024年11月16日
2024年11月16日
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV
- VA-Hair(OriginalBroadwayCastRecording)(1968)(PBTHAL24-96FLAC)
- 博主分享《美末2RE》PS5 Pro运行画面 玩家仍不买账
- 《双城之战2》超多新歌MV发布:林肯公园再次献声
- 群星《说唱梦工厂 第11期》[320K/MP3][63.25MB]
- 群星《说唱梦工厂 第11期》[FLAC/分轨][343.07MB]
- 群星《闪光的夏天 第5期》[320K/MP3][79.35MB]
- 秀兰玛雅.1999-友情人【大旗】【WAV+CUE】
- 小米.2020-我想在城市里当一个乡下人【滚石】【FLAC分轨】
- 齐豫.2003-THE.UNHEARD.OF.CHYI.3CD【苏活音乐】【WAV+CUE】
- 黄乙玲1986-讲什么山盟海誓[日本东芝版][WAV+CUE]
- 曾庆瑜1991-柔情陷阱[台湾派森东芝版][WAV+CUE]
- 陈建江《享受男声》DTS-ES6.1【WAV】