国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue2.0在table中實(shí)現(xiàn)全選和反選的示例代碼

2019-11-19 14:59:46
字體:
供稿:網(wǎng)友

其實(shí)在去年小穎已經(jīng)寫過一篇:Vue.js實(shí)現(xiàn)checkbox的全選和反選

小穎今天在跟著慕課網(wǎng)學(xué)習(xí)vue的過程中,順便試試如何在table中實(shí)現(xiàn)全選和反選,頁面的css樣式是直接參考慕課網(wǎng)的樣式寫的,js是小穎自己寫噠,歡迎大家吐槽和點(diǎn)贊,嘻嘻

demo的  git 地址:ShoppingCart

頁面效果:

具體怎么實(shí)現(xiàn)的呢?

使用localstorage來存儲(chǔ)頁面信息 中已經(jīng)有寫項(xiàng)目是怎么創(chuàng)建的所以小穎在這里就不重復(fù)了,其實(shí)只是在上篇文章的基礎(chǔ)上稍微做了改動(dòng):

App.vue文件

<template> <div id="app">  <router-view/> </div></template><script>export default { name: 'app'}</script><style>#app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; color: #2c3e50;}li,dl,dt,dd,h1,h2,h3,h4,h5,h6,hgroup,p,blockquote,figure,form,fieldset,input,legend,pre,abbr,button { margin: 0; padding: 0;}ul,ol { list-style: none; margin: 0; padding: 0;}*,*::before,*::after { box-sizing: border-box;}div,p,dl,dt,dd { margin: 0; padding: 0;}a { color: inherit; text-decoration: none;}.checkout-title { position: relative; margin-bottom: 41px; text-align: center;}.checkout-title::before { position: absolute; top: 50%; left: 0; content: ""; width: 100%; height: 1px; background: #ccc; z-index: 0;}.checkout-title span { position: relative; padding: 0 1em; background-color: #fff; font-family: "moderat", sans-serif; font-weight: bold; font-size: 20px; color: #605F5F; z-index: 1;}</style>

home.vue文件

<template> <div class="container">  <div class="checkout-title">   <span>購物車</span>  </div>  <table class="product_table">   <tbody>    <template v-for="(list,index) in table_list">     <tr>      <td width="7%" min-width="94px" v-if="index===0">       <input type="checkbox" v-model='checked' v-on:click='checkedAll'></td>      <td width="7%" v-if="index!==0">       <input type="checkbox" v-model='checkList' :value="list.id">      </td>      <td width="43%">{{list.product_inf}}</td>      <td width="10%" v-if="index===0">{{list.product_price}}</td>      <td width="10%" v-if="index!==0">¥{{list.product_price}}</td>      <td width="10%">{{list.product_quantity}}</td>      <td width="10%">{{list.total_amount}}</td>      <td width="20%" v-if="index===0">編輯</td>      <td width="20%" v-if="index!==0">       <a href="#" rel="external nofollow" rel="external nofollow" class="update">修改</a>       <a href="#" rel="external nofollow" rel="external nofollow" class="delete">刪除</a>      </td>     </tr>    </template>   </tbody>  </table>  <div class="price_total_bottom">   <div class="price_total_ms">    <label>合計(jì):{{allProductTotal}}</label>    <router-link to="/userAddress">結(jié)賬</router-link>   </div>  </div> </div></template><script>import userAddress from './address'export default { components: {  userAddress }, data() {  return {   table_list: [{    'id': 0,    'product_inf': '商品信息',    'product_price': '商品金額',    'product_quantity': '商品數(shù)量',    'total_amount': '總金額'   }, {    'id': '1',    'product_inf': '女士銀手鏈',    'product_price': 120,    'product_quantity': 200,    'total_amount': 24000   }, {    'id': '2',    'product_inf': '女士銀手鐲',    'product_price': 380,    'product_quantity': 200,    'total_amount': 72000   }, {    'id': '3',    'product_inf': '女士銀耳環(huán)',    'product_price': 100,    'product_quantity': 200,    'total_amount': 20000   }],   checked: false,   allProductTotal: null,   checkList: ['1', '3']  } }, methods: {  checkedAll: function() {   var _this = this;   console.log(_this.checkList);   if (_this.checked) { //實(shí)現(xiàn)反選    _this.checkList = [];   } else { //實(shí)現(xiàn)全選    _this.checkList = [];    _this.table_list.forEach(function(item, index) {     if (index > 0) {      _this.checkList.push(item.id);     }    });   }  } }, watch: { //深度 watcher  'checkList': {   handler: function(val, oldVal) {    if (val.length === this.table_list.length - 1) {     this.checked = true;    } else {     this.checked = false;    }   },   deep: true  } }}</script><!-- Add "scoped" attribute to limit CSS to this component only --><style scoped>.container { padding: 69px 0 54px 0;}table { border-collapse: collapse; border-color: transparent; text-align: center;}.product_table,.product_table tbody { width: 100%}.product_table tr:first-child { background: #ece6e6; color: #e66280; font-size: 20px;}.product_table td { border: 1px solid #f3e8e8; height: 62px; line-height: 62px;}.product_table a.update:link,.product_table a.update:visited,.product_table a.update:hover,.product_table a.update:active { color: #1CE24A;}.product_table a.delete:link,.product_table a.delete:visited,.product_table a.delete:hover,.product_table a.delete:active { color: #ffa700;}.price_total_bottom { font-size: 20px; padding: 20px 10px;}.price_total_ms { text-align: right;}.price_total_bottom .price_total_ms label { margin-right: 100px;}.price_total_bottom .price_total_ms a { cursor: default; text-align: center; display: inline-block; font-size: 20px; color: #fff; font-weight: bold; width: 220px; height: 54px; line-height: 54px; border: 0; background-color: #f71455;}</style>

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 麻城市| 元朗区| 静安区| 融水| 康乐县| 洪洞县| 庄浪县| 方城县| 洪江市| 香格里拉县| 五华县| 陆丰市| 平潭县| 无为县| 益阳市| 贵港市| 浏阳市| 云霄县| 台东市| 德江县| 清流县| 双峰县| 曲麻莱县| 东海县| 揭西县| 江永县| 二手房| 孝感市| 庄浪县| 昌黎县| 廊坊市| 隆安县| 聊城市| 武义县| 金溪县| 龙泉市| 北流市| 仲巴县| 东港市| 醴陵市| 香格里拉县|