真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

在vue和element-ui的table中實現(xiàn)分頁復(fù)選功能

背景

創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計制作、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的慶元網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

后臺管理系統(tǒng)中,使用表格展示數(shù)據(jù)時,可能的需求是多項選擇然后進行批量操作,也期望能翻頁多選。

實現(xiàn)

在vue和element-ui的table中實現(xiàn)分頁復(fù)選功能 

頁面結(jié)構(gòu)如下


 
 
 
 
 
 

 
 
 


模擬數(shù)據(jù)實現(xiàn)分頁

data () {
 return {
 tableData: [],
 multipleSelection: [],
 pagination: {
  currentPage: 1,
  size: 10,
  total: 1000
 }
 }
},
beforeMount () {
 this.fetchData()
},
methods: {
 fetchData () {
 this.tableData = []
 let start = (this.pagination.currentPage - 1) * this.pagination.size
 let end = this.pagination.currentPage * this.pagination.size
 setTimeout(_ => {
  for (let i = start; i < end; i++) {
  this.tableData.push({
   id: i,
   name: `王${i}蘭`
  })
  }
 }
 },
 handleCurrentChange () {
 this.fetchData()
 },
 handleSelectionChange (val) {
 this.multipleSelection = val
 },
}

展示已選擇項

已選:{{ allMultipleSelection }}
allMultipleSelection: [],

在復(fù)選事件中對所選項進行存儲

主要思路就是:

  • 將當前頁已選數(shù)據(jù)放入所有已選項
  • 將所有已選項數(shù)據(jù)中當前頁沒選擇的項移除
handleSelectionChange (val) {
 this.multipleSelection = val
 // @tip 實現(xiàn)分頁復(fù)選
 console.log(val, 'selection')
 setTimeout(_ => {
 this.resolveAllSelection()
 }, 50)
},
resolveAllSelection () {
 let currentPageData = this.tableData.map(item => item[this.uniqueKey]) // 當前頁所有數(shù)據(jù)
 let currentPageSelected = this.multipleSelection.map(item => item[this.uniqueKey]) // 當前頁已選數(shù)據(jù)
 let currentPageNotSelected = currentPageData.filter(item => !currentPageSelected.includes(item)) // 當前頁未選數(shù)據(jù)
 // 將當前頁已選數(shù)據(jù)放入所有已選項
 currentPageSelected.forEach(item => {
 if (!this.allMultipleSelection.includes(item)) {
  this.allMultipleSelection.push(item)
 }
 })
 // 將所有已選項數(shù)據(jù)中當前頁沒選擇的項移除
 currentPageNotSelected.forEach(item => {
 let idx = this.allMultipleSelection.indexOf(item)
 if (idx > -1) {
  this.allMultipleSelection.splice(idx, 1)
 }
 })
 console.log(this.allMultipleSelection, 'all')
},

此時還需要在切換頁面時將之間選擇項進行重新選中,即遍歷當前頁所有數(shù)據(jù)如果存在于所有已選項中,則將其置為已選擇。

fetchData () {
 // ...
 setTimeout(_ => {
 // ...
 // @tip 實現(xiàn)分頁復(fù)選
 setTimeout(_ => {
  this.setSelectedRow()
 }, 50)
 }, 200)
},
setSelectedRow () {
 // 設(shè)置當前頁已選項
 this.tableData.forEach(item => {
 if (this.allMultipleSelection.includes(item[this.uniqueKey])) {
  this.$refs.asTable.toggleRowSelection(item, true)
  console.log(item[this.uniqueKey], 'set')
 }
 })
},

在vue和element-ui的table中實現(xiàn)分頁復(fù)選功能 

以上實現(xiàn)了分頁復(fù)選功能。

所有代碼存放在 @careteen/lan-vue

查看DEMO

clone倉庫并引入依賴

git clone git@github.com:careteenL/lan-vue.git
npm install
npm run serve

瀏覽器打開 http://localhost:8080/#/examples/pagingCheck 即可看到效果

總結(jié)

以上所述是小編給大家介紹的在vue和element-ui的table中實現(xiàn)分頁復(fù)選功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!


新聞標題:在vue和element-ui的table中實現(xiàn)分頁復(fù)選功能
網(wǎng)址分享:http://weahome.cn/article/gissie.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部