JS表的類比方法,JS表類比方法

來源:互聯網
上載者:User

JS表的類比方法,JS表類比方法

本文執行個體講述了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程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.