vue實現(xiàn)移動端table表格簡單方法
vue實現(xiàn)移動端的table表格,效果圖如下:
主要實現(xiàn)功能:
1,表頭字段可以進行正序倒序排序功能;
2,可以展開收起;
3,藍色這一行是合計數(shù)據(jù) 需要單獨出來進行渲染,否則排序的時候此行會排亂掉;
用到的模擬數(shù)據(jù)會放到最后面;
4,注意表頭數(shù)據(jù)thList,title是標題,isSort是否可以進行排序,backgroundColor是表示是否添加特殊的背景顏色;sortField是根據(jù)什么字段進行排序;
vue代碼如下:
<template> <div class="organizationDetails"> <!-- 內(nèi)容區(qū) --> <div class="table-content" :class="controlHeight"> <table ref="table" class="table"> <!-- 表頭 --> <tr class="top"> <th v-for="(item_th, index_th) in thList" :key="index_th" :style="{ background: item_th.backgroundColor }"> <span class="title">{{ item_th.title }}</span> <span class="sort" v-if="item_th.isSort" @click="needSort(item_th.sortField, index_th)" :class="[sortIndex === index_th && isNeedSort ? 'sortUp' : '']"></span> </th> </tr> <!-- 第一行的合計數(shù)據(jù) 需要高亮 --> <tr class="cont sum" v-for="(item, index) in totalData" :key="index + Math.random() * 24"> <td>{{ item.comname2 }}</td> <td>{{ item.addAgent }}</td> <td>{{ item.addAgentRate }}</td> <td>{{ item.preium }}</td> <td>{{ item.premiumRate }}</td> </tr> <!--展示列表數(shù)據(jù) --> <tr class="cont" v-for="(item_tr, index_tr) in data11" :key="index_tr"> <td>{{ item_tr.comname2 }}</td> <td>{{ item_tr.addAgent }}</td> <td>{{ item_tr.addAgentRate }}</td> <td>{{ item_tr.preium }}</td> <td>{{ item_tr.premiumRate }}</td> </tr> </table> </div> <!-- 顯示更多和收取 點擊更多就展開 --> <div class="more" v-if="showMoreCom"> <span :colspan="thList.length" @click="showMoreFun(true)" v-if="!showMore"> 更多 <van-icon name="arrow-down" /> </span> <span :colspan="thList.length" @click="showMoreFun2(false)" v-else> 收起全部 <van-icon name="arrow-up" /> </span> </div> </div> </template> <script> import { data11, totalData } from './mock/data.js'; export default { data() { return { // 數(shù)據(jù) data11: [], totalData: [], // 表頭列表 thList: [ { title: '機構(gòu)', isSort: false, }, { title: '保費', isSort: true,// 是否進行排序 backgroundColor: '#fdeeee', // 是否單獨顯示背景顏色 sortField: 'addAgent',// 排序字段 }, { title: '達成率', isSort: true, backgroundColor: '#fdeeee', sortField: 'addAgentRate', }, { title: '新增代理人', isSort: true, sortField: 'preium', }, { title: '代理人達成率', isSort: true, sortField: 'premiumRate', }, ], // 是否需要排序 默認不進行排序 isNeedSort: false, // 排序序號 sortIndex: null, // 排序形式 倒敘默認倒敘 false為正序 order: true, // 是否顯示更多 showMore: this.showMoreCom, }; }, computed: { // 控制展開和收起的類名 controlHeight() { if (this.showMore) { return 'normalHeight'; } else { return 'controlHeight'; } }, // 判斷是否展開 這里判斷如果數(shù)大于11條時就進行顯示展開 showMoreCom() { return this.data11.length > 11; }, }, watch: { // 監(jiān)聽是否需要排序 與排序形式相統(tǒng)一 這是比較簡便的方法 isNeedSort: { handler(newV) { this.order = newV; }, immediate: true, // 注意 這里要立即進行觸發(fā) }, }, created() { this.data11 = data11; this.totalData = totalData; // 合計數(shù)據(jù) }, mounted() {}, methods: { chooseYearMonth(date) { this.yearMonth = date; }, // 控制顯示更多 showMoreFun(boolean) { this.showMore = boolean; }, showMoreFun2(boolean) { this.showMore = boolean; }, // 點擊排序處理排序箭頭 然后調(diào)用排序方法 需要處理防抖 needSort(sortField, index) { // 排序完成的數(shù)據(jù) 再次點擊排序就恢復初始值 if (this.isNeedSort) { this.isNeedSort = false; this.sortIndex = null; this.startSort(sortField, this.order); return; } this.isNeedSort = true; this.sortIndex = index; this.startSort(sortField, this.order); }, // 開始排序 第一個參數(shù)是根據(jù)什么排序 第二個參數(shù)是倒序默認值 startSort(sortField, order) { this.data11 = this.data11.sort((a, b) => { // 進行轉(zhuǎn)換一下 let value1 = b[sortField]; let value2 = a[sortField]; if (order) { // 倒序 return parseFloat(this.delete(value1)) - parseFloat(this.delete(value2)); } else { // 正序 return parseFloat(this.delete(value2)) - parseFloat(this.delete(value1)); } }); }, // 處理字符串 delete(str) { if (typeof str === 'string') { return str.split(',').join(''); } else { return str; } }, }, }; </script> <style scoped lang="scss"> // 控制高度 .controlHeight { height: 485px; overflow: hidden; transition: 0.3s; } // 正常高度 .normalHeight { height: 100%; transition: 0.3s; } // 頭部 .header { display: flex; justify-content: space-between; align-items: center; padding: 0 10px; height: 40px; } // 表格相關樣式 table { border-collapse: collapse; width: 98%; margin: 0 auto; text-align: center; font-size: 14px; // 每一行下面加邊框 tr { border-bottom: 1px solid #f1f1f1; } .cont { height: 40px; } } // 表頭設置 .top { height: 40px; line-height: 40px; background: rgb(242, 245, 247); .title { margin-right: 3px; } th { border-left: 1px solid #e9ebec; font-weight: 500; } } // 合計一行高亮顯示 .sum { color: #005dff; font-weight: bold; } // 正常排序的樣式 .sort { display: inline-block; width: 7px; height: 10px; background-image: url(); background-size: cover; background-position: 50%; background-repeat: no-repeat; } // 激活排序的樣式 .sortUp { background-image: url(); } .more { height: 40px; text-align: center; line-height: 40px; span { display: inline-block; } span:active { transition: height 0.3s; } } </style>
模擬數(shù)據(jù) data.js 如下:
// 模擬數(shù)據(jù) 11月份機構(gòu)詳細 export const data11 = [ { comname2: '貴州', addAgent: 136, addAgentRate: '26.8%', preium: '1,005.0', premiumRate: '143.6%', }, { comname2: '遼寧', addAgent: 201, addAgentRate: '100.5%', preium: '805.8', premiumRate: '71.1%', children: [ { comname2: '遼陽', addAgent: 100, addAgentRate: '120.5%', preium: '805.8', premiumRate: '71.1%', }, { comname2: '沈陽', addAgent: 101, addAgentRate: '130.5%', preium: '805.8', premiumRate: '71.1%', }, ], }, { comname2: '四川', addAgent: 27, addAgentRate: '13.5%', preium: '769.2', premiumRate: '100.9%', }, { comname2: '江西', addAgent: 306, addAgentRate: '102%', preium: '748.8', premiumRate: '213.9%', }, { comname2: '云南', addAgent: 42, addAgentRate: '8%', preium: '643.0', premiumRate: '213.6%', }, { comname2: '福建', addAgent: 45, addAgentRate: '9.7%', preium: '514.5', premiumRate: '93.5%', }, { comname2: '河南', addAgent: 26, addAgentRate: '26%', preium: '512.1', premiumRate: '88.3%', }, { comname2: '安徽', addAgent: 1, addAgentRate: '0.3%', preium: '398.7', premiumRate: '102.2%', }, { comname2: '甘肅', addAgent: 43, addAgentRate: '10.4%', preium: '393.6', premiumRate: '69.3%', }, { comname2: '陜西', addAgent: 52, addAgentRate: '12.3%', preium: '374.5', premiumRate: '46.8%', }, { comname2: '湖南', addAgent: 53, addAgentRate: '10.2%', preium: '356.5', premiumRate: '45%', }, { comname2: '海南', addAgent: 36, addAgentRate: '12.8%', preium: '341.3', premiumRate: '103.7%', }, { comname2: '湖北', addAgent: 25, addAgentRate: '6.5%', preium: '336.5', premiumRate: '98.1%', }, { comname2: '青島', addAgent: 10, addAgentRate: '6.7%', preium: '289.0', premiumRate: '111.1%', }, { comname2: '黑龍江', addAgent: 5, addAgentRate: '2.2%', preium: '286.2', premiumRate: '54%', }, { comname2: '廣東', addAgent: 17, addAgentRate: '3.5%', preium: '265.9', premiumRate: '57.8%', }, { comname2: '重慶', addAgent: 46, addAgentRate: '31.3%', preium: '240.6', premiumRate: '88.5%', }, { comname2: '江蘇', addAgent: 40, addAgentRate: '9.6%', preium: '238.2', premiumRate: '34%', }, { comname2: '山西', addAgent: 178, addAgentRate: '57.6%', preium: '214.9', premiumRate: '75.1%', }, { comname2: '新疆', addAgent: 13, addAgentRate: '130%', preium: '189.1', premiumRate: '370.8%', }, { comname2: '青海', addAgent: 6, addAgentRate: '3.9%', preium: '152.1', premiumRate: '257.8%', }, { comname2: '寧夏', addAgent: 7, addAgentRate: '2.5%', preium: '144.1', premiumRate: '87.9%', }, { comname2: '廣西', addAgent: 0, addAgentRate: '0%', preium: '108.7', premiumRate: '63.9%', }, { comname2: '寧波', addAgent: 8, addAgentRate: '14.3%', preium: '106.8', premiumRate: '113.6%', }, { comname2: '天津', addAgent: 16, addAgentRate: '7.8%', preium: '96.0', premiumRate: '68.6%', }, { comname2: '蘇州', addAgent: 0, addAgentRate: '0%', preium: '21.2', premiumRate: '0%', }, { comname2: '廈門', addAgent: 0, addAgentRate: '0%', preium: '0.2', premiumRate: '0.4%', }, { comname2: '深圳', addAgent: 0, addAgentRate: '0%', preium: '0.0', premiumRate: '0%', }, { comname2: '無錫', addAgent: 0, addAgentRate: '0%', preium: '0.0', premiumRate: '0%', }, { comname2: '上海', addAgent: 0, addAgentRate: '0%', preium: '0.0', premiumRate: '0%', }, { comname2: '北京', addAgent: 0, addAgentRate: '0%', preium: '0.0', premiumRate: '0%', }, ]; // 第一行合計數(shù)據(jù) export const totalData = [ { comname2: '合計', addAgent: 2864, addAgentRate: '29.7%', preium: '16,474.7', premiumRate: '94.9%', }, ];
總結(jié)
到此這篇關于vue實現(xiàn)移動端table表格的文章就介紹到這了,更多相關vue移動端table表格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用vue-cli創(chuàng)建vue2項目的實戰(zhàn)步驟詳解
相信大部分Vue開發(fā)者都使用過vue-cli來構(gòu)建項目,它的確很方便,但對于很多初級開發(fā)者來說,還是要踩不少坑的,下面這篇文章主要給大家介紹了關于使用vue-cli創(chuàng)建vue2項目的實戰(zhàn)步驟,需要的朋友可以參考下2023-01-01利用Vue Router實現(xiàn)單頁面應用(SPA)的代碼示例
在當今前端開發(fā)中,單頁面應用(SPA)已成為一種主流的開發(fā)模式,它通過在用戶與網(wǎng)頁之間提供更流暢的交互體驗,來改變傳統(tǒng)多頁面應用的思維,本文將詳細介紹如何利用 Vue.js 中的 Vue Router 來實現(xiàn)一個簡單的單頁面應用,需要的朋友可以參考下2025-01-01結(jié)合Vue控制字符和字節(jié)的顯示個數(shù)的示例
這篇文章主要介紹了結(jié)合Vue控制字符和字節(jié)的顯示個數(shù)的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05vue調(diào)用微信JSDK 掃一掃,相冊等需要注意的事項
這篇文章主要介紹了vue調(diào)用微信JSDK 掃一掃,相冊等需要注意的事項,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01vue?scss后綴文件background-image路徑錯誤的解決
這篇文章主要介紹了vue?scss后綴文件background-image路徑錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12解決vue create 創(chuàng)建項目只有兩個文件問題
這篇文章主要介紹了解決vue create 創(chuàng)建項目只有兩個文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02Vue.js中extend選項和delimiters選項的比較
這篇文章主要介紹了Vue.js中extend選項和delimiters選項的比較的相關資料,需要的朋友可以參考下2017-07-07