亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用elementUI table展開行內(nèi)嵌套table問題

 更新時間:2023年04月18日 14:49:35   作者:知所云  
這篇文章主要介紹了使用elementUI table展開行內(nèi)嵌套table問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

elementUI table展開行內(nèi)嵌套table

需求

產(chǎn)品需要table展開行內(nèi)嵌套一個可以翻頁的table,emmm·····我也不知道她咋想的,那么需要就得試下呀

使用 vue + elementUI

首先,elementui提供了table展開行的一個功能,那么就在這個功能上改造就好了,如果實現(xiàn)的不算特別好,別打我

上代碼

<template>
? <el-table
? ? :data="tableData"
? ? style="width: 100%">
? ? <el-table-column type="expand">
? ? ? <template slot-scope="props">
? ? ? ? <el-form label-position="left" inline class="demo-table-expand">
? ? ? ? ? <el-form-item label="商品名稱">
? ? ? ? ? ? <span>{{ props.row.name }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="所屬店鋪">
? ? ? ? ? ? <span>{{ props.row.shop }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="商品 ID">
? ? ? ? ? ? <span>{{ props.row.id }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="店鋪 ID">
? ? ? ? ? ? <span>{{ props.row.shopId }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="商品分類">
? ? ? ? ? ? <span>{{ props.row.category }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="店鋪地址">
? ? ? ? ? ? <span>{{ props.row.address }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? ? <el-form-item label="商品描述">
? ? ? ? ? ? <span>{{ props.row.desc }}</span>
? ? ? ? ? </el-form-item>
? ? ? ? </el-form>
? ? ? </template>
? ? </el-table-column>
? ? <el-table-column
? ? ? label="商品 ID"
? ? ? prop="id">
? ? </el-table-column>
? ? <el-table-column
? ? ? label="商品名稱"
? ? ? prop="name">
? ? </el-table-column>
? ? <el-table-column
? ? ? label="描述"
? ? ? prop="desc">
? ? </el-table-column>
? </el-table>
</template>
<style>
? .demo-table-expand {
? ? font-size: 0;
? }
? .demo-table-expand label {
? ? width: 90px;
? ? color: #99a9bf;
? }
? .demo-table-expand .el-form-item {
? ? margin-right: 0;
? ? margin-bottom: 0;
? ? width: 50%;
? }
</style>
<script>
? export default {
? ? data() {
? ? ? return {
? ? ? ? tableData: [{
? ? ? ? ? id: '12987122',
? ? ? ? ? name: '好滋好味雞蛋仔',
? ? ? ? ? category: '江浙小吃、小吃零食',
? ? ? ? ? desc: '荷蘭優(yōu)質(zhì)淡奶,奶香濃而不膩',
? ? ? ? ? address: '上海市普陀區(qū)真北路',
? ? ? ? ? shop: '王小虎夫妻店',
? ? ? ? ? shopId: '10333'
? ? ? ? }, {
? ? ? ? ? id: '12987123',
? ? ? ? ? name: '好滋好味雞蛋仔',
? ? ? ? ? category: '江浙小吃、小吃零食',
? ? ? ? ? desc: '荷蘭優(yōu)質(zhì)淡奶,奶香濃而不膩',
? ? ? ? ? address: '上海市普陀區(qū)真北路',
? ? ? ? ? shop: '王小虎夫妻店',
? ? ? ? ? shopId: '10333'
? ? ? ? }, {
? ? ? ? ? id: '12987125',
? ? ? ? ? name: '好滋好味雞蛋仔',
? ? ? ? ? category: '江浙小吃、小吃零食',
? ? ? ? ? desc: '荷蘭優(yōu)質(zhì)淡奶,奶香濃而不膩',
? ? ? ? ? address: '上海市普陀區(qū)真北路',
? ? ? ? ? shop: '王小虎夫妻店',
? ? ? ? ? shopId: '10333'
? ? ? ? }, {
? ? ? ? ? id: '12987126',
? ? ? ? ? name: '好滋好味雞蛋仔',
? ? ? ? ? category: '江浙小吃、小吃零食',
? ? ? ? ? desc: '荷蘭優(yōu)質(zhì)淡奶,奶香濃而不膩',
? ? ? ? ? address: '上海市普陀區(qū)真北路',
? ? ? ? ? shop: '王小虎夫妻店',
? ? ? ? ? shopId: '10333'
? ? ? ? }]
? ? ? }
? ? }
? }
</script>

這個是elementui提供的,那么需要改造el-table-column type=“expand”

代碼如下

?<el-table-column fixed="right" align="center" label="操作" width="80" type="expand">
? ? ? ? ? <template slot-scope="scope" ? v-loading.fullscreen.lock="loading">
? ? ? ? ? ? <tableList :pageInfo='pageInfo' v-if="showTableData" :tableData="scope.row.children" @getListInfo="getListInfo" @currentChange='currentChangeTableList'></tableList>
? ? ? ? ? </template>
?</el-table-column>

tableList是展開行內(nèi)放的table,正常些就好了,但是遇到的問題是,這個點展開的時候table里面的數(shù)據(jù)是動態(tài)獲取的,剛開始直接定義的是tableData是直接等于動態(tài)獲取的值(:tableData=“tableData” 這??樣子的),但是數(shù)據(jù)有,頁面卻不更新,很多方法試了都不行,emmmm。。。。

有點坑,然后看提供的是從scope.row的children獲取數(shù)據(jù)的,所以接口獲取數(shù)據(jù)之后set進這個row的children內(nèi)就可以實現(xiàn)了,但是前提要獲取這個行所在的index,剛好這邊需求是展開后其他展開行要收起,所以兩個結(jié)合一下就能實現(xiàn)了

<el-table
? ? ? ? :data="list"
? ? ? ? stripe
? ? ? ? border
? ? ? ? size="small"
? ? ? ? :height="tableHeight"
? ? ? ? v-loading="loading"
? ? ? ? :row-key="getRowKeys"
? ? ? ? :expand-row-keys="expands"
? ? ? ? element-loading-text="拼命加載中"
? ? ? ? @expand-change="expandChange"> // ?? ?當用戶對某一行展開或者關(guān)閉的時候會觸發(fā)該事件(展開行時,回調(diào)的第二個參數(shù)為 expandedRows;樹形表格時第二參數(shù)為 expanded)
? ? ??
? ? ? ? <el-table-column fixed="right" align="center" label="操作" width="80" type="expand">
? ? ? ? ? <template slot-scope="scope" ? v-loading.fullscreen.lock="loading">
? ? ? ? ? ? <tableList :pageInfo='pageInfo' v-if="showTableData" :tableData="scope.row.children" @getListInfo="getListInfo" @currentChange='currentChangeTableList'></tableList>
? ? ? ? ? </template>
? ? ? ? </el-table-column>
? ? ? </el-table>

js代碼

?data() {
? ? return {
? ? pageInfo:{
? ? ? ? total:0,
? ? ? ? pageNo:1,
? ? ? ? pageSize:5
? ? },
? ? expands: [] ,
? ? ? list: [], // table數(shù)據(jù)
? ? ? getRowKeys(row) { // 行數(shù)據(jù)的Key
? ? ? ? ?return row.vehID
? ? ? },
??
? },
? methods:{
? ?expandChange(row,expandedRows){
? ? ? this.showTableData = false
? ? ? this.expands = []
? ? ? if (expandedRows.length > 0) {
? ? ? ? ?row ? this.expands.push(row.vehID) : '' // 只展開一行
? ? ? ? ?this.indexRow = this.list.indexOf(row) ?//獲取index值,在展開請求數(shù)據(jù)后set進row的children
? ? ? ? this.pageInfo.pageNo = 1
? ? ? ? this.queryBigDataOutList() // 接口請求的方法
? ? ? }
? ? },
? }

到這里差不多就完成了,但是在點擊內(nèi)部table翻頁的時候數(shù)據(jù)更新會出現(xiàn)問題,所以給tableList設(shè)置了v-if這樣數(shù)據(jù)就可以實時更新渲染頁面了,因為接口請求反應(yīng)會比較慢,所以加了一個v-loading.fullscreen.lock="loading"加載

elementui展開行踩過的坑

項目需求使用展開行實現(xiàn)表格嵌套,且要根據(jù)當前點擊的行來動態(tài)獲取展開行中的數(shù)據(jù)

總結(jié)一下踩過的坑

1.展開行中的表格data綁定的必須是外層表格中的數(shù)據(jù)的子項,否則會出現(xiàn)第一次點擊展開嵌套表格不顯示,點擊兩次才會顯示的bug

export default {
? ? data(){
? ? ? ? return{
? ? ? ? ? ? tableData:[{ ? ? //外層綁定的data
? ? ? ? ? ? ?? ?name:'xiaoming',
? ? ? ? ? ? ?? ?age:'18',
? ? ? ? ? ? ?? ?rowData:[], ? ?//展開行表格綁定的data
? ? ? ? ? ? }],
? ? ? ? }
? ? },
}

但是這個方法需要每次點擊的時候獲取到當前點擊行的index,并異步請求獲取數(shù)據(jù)添加到外層表格綁定的data中,這樣有些麻煩,我想單獨定義一個變量來綁定嵌套的表格

get到一個不是太好的解決方法,在展開行的tem中加上slot-scope=“scope”,但下面不用使用這個scope,vscode中可能會紅線報錯,但不影響正常效果

? ? <el-table-column
? ? ?type="expand">
? ? ? ? <template slot-scope="scope"> ? //這里scope會報錯
? ? ? ? ?? ?<el-table?
? ? ? ? ?? ?:data="rowData">
? ? ? ? ?? ??? ?...
? ? ? ? ?? ?</el-table>
? ? ? ? </template>
? ? </el-table-column>

export default {
? ? data(){
? ? ? ? return{
? ? ? ? ? ? tableData:[], ? ?//外層綁定的data
? ? ? ? ? ? rowData:[], ? ?//展開行表格綁定的data
? ? ? ? }
? ? },
}

2.因為嵌套表格的數(shù)據(jù)是動態(tài)獲取的,所以要保證每次只能展開一行,展開多行會出現(xiàn)每個展開行的表格數(shù)據(jù)都是一樣的bug

實現(xiàn)每次只能展開一行,給外層表格添加如下屬性

tem

?? ?<el-table?
?? ??? ?:data="tableData"
?? ??? ?:row-key='getRowKeys'
?? ? ? ?? ?:expand-row-keys="expands"
?? ? ? ?? ?@expand-change="expandChange">
?? ? ??? ??? ?...
??? ?</el-table>

js:

?? ?export default {
? ? data(){
? ? ? ? return{
? ? ? ? ? ? tableData:[], ? ?//外層綁定的data
? ? ? ? ? ? rowData:[], ? ?//展開行表格綁定的data
? ? ? ? ? ? expands: [],
? ? ? ? ? ? getRowKeys (row) {
? ? ? ? ? ? ? return row.id
? ? ? ? ? ? },
? ? ? ? }
? ? },
? ? ?methods:{
?? ??? ?//展開行選項變化時觸發(fā)
? ? ? ? expandChange(row,expandedRows){
? ? ? ? ? ? this.rowData = []
? ? ? ? ? ? var that = this
? ? ? ? ? ? if (expandedRows.length) {
? ? ? ? ? ? ? that.expands = []
? ? ? ? ? ? ? if (row) {
? ? ? ? ? ? ? ? that.expands.push(row.id)
? ? ? ? ? ? ? }
? ? ? ? ? ? } else {
? ? ? ? ? ? ? that.expands = []
? ? ? ? ? ? }

? ? ? ? ? ? this.$http({ ? ?//發(fā)送異步請求獲取嵌套表格數(shù)據(jù)
? ? ? ? ? ? ? ? ···
? ? ? ? ? ? }).then(({data})=>{
? ? ? ? ? ? ? ? this.rowData = data.list
? ? ? ? ? ? })
? ? ? ? },
?? ?}
}

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue導出Excel功能的全過程記錄

    Vue導出Excel功能的全過程記錄

    在開發(fā)后臺管理系統(tǒng)的時候,很多地方都要用到導出excel 表格,比如將table中的數(shù)據(jù)導出到本地,這篇文章主要給大家介紹了關(guān)于Vue導出Excel功能的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • Vue3項目中的hooks的使用教程

    Vue3項目中的hooks的使用教程

    今天我們稍微說一下 vue3 項目中的 hooks 的使用,其實這個 hooks 呢是和 vue2 當中的 mixin 是類似的,學習過 vue2 的小伙伴一定對 mixin 一定比較熟悉,快跟隨小編一起來學習學習吧
    2022-08-08
  • vue+element-ui+axios多文件上傳的實現(xiàn)并顯示整體進度

    vue+element-ui+axios多文件上傳的實現(xiàn)并顯示整體進度

    這篇文章主要介紹了vue+element-ui+axios多文件上傳的實現(xiàn)并顯示整體進度,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue跨域處理方式(vue項目中baseUrl設(shè)置問題)

    vue跨域處理方式(vue項目中baseUrl設(shè)置問題)

    這篇文章主要介紹了vue跨域處理方式(vue項目中baseUrl設(shè)置問題),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 使用vite創(chuàng)建vue3項目的詳細圖文教程

    使用vite創(chuàng)建vue3項目的詳細圖文教程

    創(chuàng)建Vue3項目有兩種常見的方式,一種是想vue2版本一樣使用腳手架工具創(chuàng)建,創(chuàng)建vue3項目的腳手架必須是4版本以上的,另一種方法就是使用vite創(chuàng)建,這篇文章主要給大家介紹了關(guān)于如何使用vite創(chuàng)建vue3項目的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • 淺談vue加載優(yōu)化策略

    淺談vue加載優(yōu)化策略

    這篇文章主要介紹了淺談vue加載優(yōu)化策略,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • axios取消請求與避免重復(fù)請求

    axios取消請求與避免重復(fù)請求

    在項目中經(jīng)常有一些場景會連續(xù)發(fā)送多個請求,而異步會導致最后得到的結(jié)果不是我們想要的,并且對性能也有非常大的影響,這篇文章主要給大家介紹了關(guān)于axios取消請求與避免重復(fù)請求的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • Vue組件之事件總線和消息發(fā)布訂閱詳解

    Vue組件之事件總線和消息發(fā)布訂閱詳解

    這篇文章主要為大家詳細介紹了Vue組件之事件總線和消息發(fā)布訂閱,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • Vue開發(fā)Sort組件代碼詳解

    Vue開發(fā)Sort組件代碼詳解

    這篇文章主要介紹了Vue開發(fā)Sort組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • vue圖片加載與顯示默認圖片實例代碼

    vue圖片加載與顯示默認圖片實例代碼

    這篇文章主要為大家詳細介紹了vue圖片加載與顯示默認圖片的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評論