VUE簡單的分頁購物清單

1.需求分析

image

可以在購物列表中添加吼具、刪除數(shù)據(jù)。添加刪除操作會改變分頁从橘。

可切換每條數(shù)據(jù)采購狀態(tài)念赶,已采購的數(shù)據(jù)才能從列表中刪除础钠。否則刪除鍵不能點擊。

頭部顯示清單總數(shù)以及未采購數(shù)

2.數(shù)據(jù)驅(qū)動

image

以總數(shù)據(jù)為核心的數(shù)據(jù)驅(qū)動(添加晶乔、刪除、選購狀態(tài))牺勾;

分頁以頁碼為核心正罢,當(dāng)前頁展示條數(shù)為必要參數(shù)

以下為data


data:{

lists:[{name:'手機(jī)1',purchased:false},//所有購物信息 purchased選購狀態(tài) false未選購,true選購

        {name:'電腦2',purchased:true},

{name:'化妝品3',purchased:false},

{name:'包4',purchased:false},

{name:'電腦5',purchased:true},

{name:'化妝品6',purchased:false},

{name:'包7',purchased:false},

{name:'電腦8',purchased:true},

{name:'化妝品9',purchased:false},

{name:'包10',purchased:false},

{name:'手機(jī)11',purchased:false},

{name:'電腦12',purchased:true},

{name:'化妝品13',purchased:false},

{name:'包14',purchased:false},

{name:'電腦15',purchased:true},

{name:'化妝品16',purchased:false},

{name:'包17',purchased:false},

{name:'電腦18',purchased:true}

],

name:"",//添加一條數(shù)據(jù)所使用的變量

    page:{//分頁相關(guān)變量

        total:1,//總分頁數(shù)

        showPageNum:1,//當(dāng)前展示頁碼

        contentNum:10,//每一頁的展示條數(shù)

    },

3.添加驻民、刪除

樣式用的全都是bootstrap

添加(html)


 <input class="form-control" type="text" v-model="name"/>

              <span class="input-group-btn">

                <button class="btn btn-primary" v-on:click="add(name)">添加</button>

              </span>

</div>

(js)


add:function(name){

if (name ==='')return;

this.lists.unshift({name:name,purchased:false});

this.name="";

this.paging();

}

this.paging();分頁翻具,后面會講,添加回还、刪除操作都會觸發(fā)重新分頁裆泳。

刪除(html)


<button type="button" class="btn btn-danger btn-sm" @click="del(index)" :disabled="!item.purchased">刪除</button>

<tr v-for="(item,index) in showList">******i****tem,index都是在v-for中獲取的

@click="del(index)" 刪除按鈕僅僅負(fù)責(zé)根據(jù)當(dāng)前數(shù)據(jù)的index刪除對應(yīng)數(shù)據(jù)。

:disabled="!item.purchased"根據(jù)選購狀態(tài)設(shè)置刪除按鈕是否禁用(https://segmentfault.com/q/1010000016214238/a-1020000016214311

image

4.分頁

根據(jù)信息總數(shù)柠硕、每頁展示頁數(shù)確定總頁數(shù)

根據(jù)當(dāng)前展示頁的頁碼工禾,以及總頁數(shù)確定當(dāng)前展示頁(針對刪除數(shù)據(jù)后頁數(shù)減少的情況)

paging:function () {//分頁

//確定總頁數(shù)

    this.page.total=Math.ceil(this.lists.length/this.page.contentNum);

if(!this.page.total)

{

this.page.total=1;

}

//確定當(dāng)前展示頁數(shù)

    this.page.showPageNum=this.page.showPageNum>this.page.total?this.page.total:this.page.showPageNum;

}

當(dāng)前展示頁(html)


<table class="table table-striped">

              <thead>

                <tr>

                  <th>序號</th>

                  <th>清單名稱</th>

                  <th>已采購</th>

                  <th>狀態(tài)</th>

                  <th>刪除</th>

                </tr>

              </thead>

              <tbody>

                <tr v-for="(item,index) in showList">

                  <td>{{serialNum(index)}}</td>

                  <td>{{item.name}}</td>

                  <td><input type="checkbox" v-model="item.purchased" ></td>

                  <td>{{item.purchased | stateFilter}}</td>

                  <td><button type="button" class="btn btn-danger btn-sm" @click="del(index)" :disabled="!item.purchased">刪除</button></td>

                </tr>

              </tbody>

            </table>

(js)


computed:{

showList:function () {

//確定當(dāng)前展示頁數(shù)據(jù)

        letstart=(this.page.showPageNum-1)*this.page.contentNum;

return  this.lists.slice(start,start+this.page.contentNum);

}

}

<tr v-for="(item,index) in showList">當(dāng)前展示頁的數(shù)據(jù)是總數(shù)據(jù)的截取,會根據(jù)頁碼蝗柔、總數(shù)據(jù)闻葵、每頁展示數(shù)目變化。所以采用計算屬性癣丧。

{{item.purchased | stateFilter}}根據(jù)采購狀態(tài)槽畔,配合過濾器顯示


filters:{//過濾器

    stateFilter:function(type){return type?"已采購":"未采購"}

},

<td>{{serialNum(index)}}</td>根據(jù)本條數(shù)據(jù)在展示頁數(shù)據(jù)中的位置來給定序號。


serialNum:function (index) {

return index+1+(this.page.showPageNum-1)*this.page.contentNum;

},

5.頁碼以及翻頁

頁碼(html)


<nav aria-label="Page navigation">

              <ul class="pagination">

                  <li @click="pagePre" :class="{disabled:page.showPageNum<=1}">

                      <a href="#" aria-label="Previous">

                          <span aria-hidden="true">&laquo;</span>

                      </a>

                  </li>

                  <li v-for="index in page.total" @click="pageTurn(index)" :class="{active:index===page.showPageNum}"><a href="#">{{index}}</a></li>

                  <li @click="pageNext" :class="{disabled:page.showPageNum>=page.total}">

                      <a href="#" aria-label="Next">

                          <span aria-hidden="true">&raquo;</span>

                      </a>

                  </li>

              </ul>

          </nav>

(js)


pageTurn:function (index) {//選擇頁數(shù)

    this.page.showPageNum=index;

this.paging();

},

pagePre:function () {//向前翻頁

    if(this.page.showPageNum>1){

this.page.showPageNum--;

}

this.paging();

},

pageNext:function () {//向后翻頁

    if(this.page.showPageNum<this.page.total){

this.page.showPageNum++;

}

this.paging();

}


<li v-for="index in page.total" @click="pageTurn(index)" :class="{active:index===page.showPageNum}"><a href="#">{{index}}</a></li>

根據(jù)當(dāng)前展示的頁碼確定擁有active樣式的頁碼胁编。


<li @click="pagePre" :class="{disabled:page.showPageNum<=1}">

                      <a href="#" aria-label="Previous">

                          <span aria-hidden="true">&laquo;</span>

                      </a>

                  </li>

根據(jù)當(dāng)前展示頁頁碼給向前向后翻頁添加禁用

6.為什么添加厢钧、刪除寫了對應(yīng)的方法修改了總的lists的數(shù)據(jù),但是通過勾選修改選購狀態(tài)沒有嬉橙。

image

如圖早直,修改a[0].name,b[0].name也會對應(yīng)的修改市框,因為他們引用的是同一個對象莽鸿。但是對b的添加刪除操作不會影響到a。

<td><input type="checkbox" v-model="item.purchased"></td>v-model動態(tài)綁定的purchase就是總數(shù)組lists中的purchased

代碼下載

所有代碼已經(jīng)上傳到我的github倉庫中拾给。

都看到這里了就點個?吧 (?▽?)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末祥得,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蒋得,更是在濱河造成了極大的恐慌级及,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件额衙,死亡現(xiàn)場離奇詭異饮焦,居然都是意外死亡怕吴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進(jìn)店門县踢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來转绷,“玉大人,你說我怎么就攤上這事硼啤∫榫” “怎么了?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵谴返,是天一觀的道長煞肾。 經(jīng)常有香客問我,道長嗓袱,這世上最難降的妖魔是什么籍救? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮渠抹,結(jié)果婚禮上蝙昙,老公的妹妹穿的比我還像新娘。我一直安慰自己梧却,他們只是感情好耸黑,可當(dāng)我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著篮幢,像睡著了一般大刊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上三椿,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天缺菌,我揣著相機(jī)與錄音,去河邊找鬼搜锰。 笑死伴郁,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蛋叼。 我是一名探鬼主播焊傅,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼狈涮!你這毒婦竟也來了狐胎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤歌馍,失蹤者是張志新(化名)和其女友劉穎握巢,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體松却,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡暴浦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年溅话,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片歌焦。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡飞几,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出独撇,到底是詐尸還是另有隱情屑墨,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布券勺,位于F島的核電站绪钥,受9級特大地震影響灿里,放射性物質(zhì)發(fā)生泄漏关炼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一匣吊、第九天 我趴在偏房一處隱蔽的房頂上張望儒拂。 院中可真熱鬧,春花似錦色鸳、人聲如沸社痛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蒜哀。三九已至,卻和暖如春吏砂,著一層夾襖步出監(jiān)牢的瞬間撵儿,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工狐血, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留淀歇,地道東北人。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓匈织,卻偏偏與公主長得像浪默,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子缀匕,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容