欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Ant Design Vue Table組件合并單元格方式

 更新時(shí)間:2023年04月20日 09:39:41   作者:木藍(lán)茶陌*_*  
這篇文章主要介紹了Ant Design Vue Table組件合并單元格方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Ant Design Vue Table組件合并單元格

項(xiàng)目開發(fā)中,有時(shí)候需要實(shí)現(xiàn)單元格合并的需求,這里記錄一下在Ant Design Vue的實(shí)現(xiàn)。

<template>
  <div>
    <a-table bordered :data-source="dataSource" :columns="columns"></a-table>
  </div>
</template>
<script>
const dataSource = [
  { key: '1', school: '林州一中', grade: '高一', class: '二班', name: '徐強(qiáng)' },
  { key: '2', school: '林州一中', grade: '高一', class: '一班', name: '林東'},
  { key: '3', school: '林州一中', grade: '高一', class: '二班', name: '李丹'},
  { key: '4', school: '林州一中', grade: '高二', class: '二班', name: '劉康'},
  { key: '5', school: '實(shí)驗(yàn)高中', grade: '高三', class: '二班', name: '楊江'},
  { key: '6', school: '實(shí)驗(yàn)高中', grade: '高三', class: '一班', name: '陳鋒'},
  { key: '7', school: '實(shí)驗(yàn)高中', grade: '高三', class: '二班', name: '李華'},
  { key: '8', school: '實(shí)驗(yàn)高中', grade: '高四', class: '二班', name: '趙銘'}
]

const columns = [
  {
    title: '學(xué)校', dataIndex: 'school', width: '25%',
    scopedSlots: { customRender: 'school' }, align: 'center', key: 'school',
    customRender (_, row) {
      return {
        children: row.school,
        attrs: {
          rowSpan: row.schoolRowSpan
        }
      }
    }
  },
  {
    title: '年級(jí)', dataIndex: 'grade', width: '25%',
    scopedSlots: { customRender: 'grade' }, align: 'center', key: 'grade',
    customRender (_, row) {
      return {
        children: row.grade,
        attrs: {
          rowSpan: row.gradeRowSpan
        }
      }
    }
  },
  {
    title: '班級(jí)', dataIndex: 'class', width: '25%',
    scopedSlots: { customRender: 'class' }, align: 'center'
  },
  {
    title: '姓名', dataIndex: 'name', width: '25%',
    scopedSlots: { customRender: 'name' }, align: 'center'
  }
]

export default {
  name: 'TableMerge',
  data () {
    return {
      dataSource,
      columns
    }
  },
  methods: {
    // 合并單元格
    rowSpan (key, data) {
      const arr = data
        .reduce((result, item) => {
          if (result.indexOf(item[key]) < 0) {
            result.push(item[key])
          }
          return result
        }, [])
        .reduce((result, keys) => {
          const children = data.filter(item => item[key] === keys)
          result = result.concat(
            children.map((item, index) => ({
              ...item,
              [`${key}RowSpan`]: index === 0 ? children.length : 0
            }))
          )
          return result
        }, [])
      return arr
    },
    // 表格合并
    mergeRowCell (data) {
      let tableData = this.rowSpan('school', data)
      tableData = this.rowSpan('grade', tableData)
      this.dataSource = tableData
    }
  },
  mounted () {
    this.mergeRowCell(this.dataSource)
  }
}
</script>

合并前:

合并第一列:

合并第二列:

Ant-vue table的單元格合并已經(jīng)使用自己的slot插槽

之前在做一個(gè)ant-design的項(xiàng)目的時(shí)候,遇到一個(gè)單元格合并的問題,簡(jiǎn)直頭疼,其實(shí)在ant中進(jìn)行簡(jiǎn)單的內(nèi)容合并單元格,其實(shí)很容易也很方便,最簡(jiǎn)單的凡是就是在a-table-column標(biāo)簽中進(jìn)行綁定一個(gè)function,代碼如下(由于之前比較喜歡template的方式,所以下面都是template的方式進(jìn)行代碼展示,js的數(shù)據(jù)方式邏輯是一樣的):

//核心是customRender這個(gè)對(duì)象
<a-table-column
data-index="logisticObj"?
width="150px"?
:customRender="mergeTable" />
//js
//children是返回的內(nèi)容,attrs里面是合并的單元格公式,后面的數(shù)字是代表幾行/列 ,如果被合并了的未知就用0進(jìn)行占位
mergeTable(text, record, index) {
?? ?return {
?? ??? ?children: text,
?? ??? ?attrs: {
?? ??? ??? ?rowSpan:1
?? ??? ?},
?? ?}
},

到這里一些簡(jiǎn)單的合并什么的基本上都能進(jìn)行處理了。

接下來難點(diǎn)來了,我們經(jīng)常會(huì)在column中進(jìn)行設(shè)置一個(gè)自己的插槽,但是貌似這這里設(shè)置一個(gè)插槽并不會(huì)進(jìn)行渲染,親測(cè)過很多次,返回的都是children中的內(nèi)容。

針對(duì)這個(gè),特意去了解了下源碼中的要求,這里只能插入 jsx 語法的代碼片段。如果是react開發(fā)的人,應(yīng)該對(duì)這個(gè)不默認(rèn),但是vue中用的 jsx 還是相對(duì)較少的,比如返回一個(gè)鏈接:

return {
?? ??? ?children: <a>text</a>,
?? ??? ?// 一個(gè)div ? <div>text<div>
?? ??? ?//一個(gè)js處理了的內(nèi)容 ? <div>{text.length}</div>
?? ??? ?//一個(gè)html的代碼字符串 <span domPropsInnerHTML = { htmlInfoStr }></span>
?? ??? ?//剩下的html代碼等類似
?? ??? ?attrs: {
?? ??? ??? ?rowSpan:1
?? ??? ?},
?? ?}

通過上面的,簡(jiǎn)單的類似于slot的使用方式也能進(jìn)行渲染了,使用真是的slot研究了一段時(shí)間,貌似沒有研究成功,如果有人有了結(jié)果,可以私信@我一下,互相學(xué)習(xí)一下。

上面這些都是一個(gè)簡(jiǎn)單的渲染方式,以及渲染的內(nèi)容替換等,真正讓我頭疼的是,如果合并的是一個(gè)按鈕組或者帶有事件的東東,這個(gè)怎么弄?

踩了一路坑,得到了一種方法,廢話不說了,代碼如下

?? ?children : (
?? ??? ?<div>
?? ??? ??? ?<div class=" spanLink"?
?? ??? ??? ?onClick={ () => this.yourFunction(a,b,c,d)}>
?? ??? ??? ?一個(gè)帶有點(diǎn)擊事件的template
?? ??? ??? ?</div>
?? ??? ?</div>
?? ?)

這里重點(diǎn)的是只能用 純 jsx 語法進(jìn)行編寫,事件推薦使用括號(hào)函數(shù)進(jìn)行帶入,參數(shù)正常傳遞就可以了。 

總結(jié)

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

相關(guān)文章

  • babel7.x和webpack4.x配置vue項(xiàng)目的方法步驟

    babel7.x和webpack4.x配置vue項(xiàng)目的方法步驟

    這篇文章主要介紹了babel7.x和webpack4.x配置vue項(xiàng)目的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • 記錄vue做微信自定義分享的一些問題

    記錄vue做微信自定義分享的一些問題

    這篇文章主要介紹了記錄vue做微信自定義分享的一些問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 教你利用Vue3模仿Windows窗口

    教你利用Vue3模仿Windows窗口

    最近學(xué)習(xí)了Vue3,利用vue3做了個(gè)好玩的項(xiàng)目,所以下面這篇文章主要給大家介紹了關(guān)于如何利用Vue3模仿Windows窗口的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • vue-cli瀏覽器實(shí)現(xiàn)熱更新的步驟

    vue-cli瀏覽器實(shí)現(xiàn)熱更新的步驟

    這篇文章主要介紹了vue-cli-瀏覽器實(shí)現(xiàn)熱更新,最常用的是webpack-dev-server,它是一個(gè)小型的Node.js?Express服務(wù)器,它使用webpack-dev-middleware來服務(wù)于webpack的包,本文結(jié)合實(shí)例代碼介紹的非常詳細(xì),需要的朋友參考下吧
    2024-03-03
  • 在vue中使用防抖和節(jié)流,防止重復(fù)點(diǎn)擊或重復(fù)上拉加載實(shí)例

    在vue中使用防抖和節(jié)流,防止重復(fù)點(diǎn)擊或重復(fù)上拉加載實(shí)例

    今天小編就為大家分享一篇在vue中使用防抖和節(jié)流,防止重復(fù)點(diǎn)擊或重復(fù)上拉加載實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue組件如何設(shè)置Props實(shí)例詳解

    Vue組件如何設(shè)置Props實(shí)例詳解

    props主要用于組件的傳值,他的工作就是為了接收外面?zhèn)鬟^來的數(shù)據(jù),與data、el、ref是一個(gè)級(jí)別的配置項(xiàng),下面這篇文章主要給大家介紹了關(guān)于Vue組件如何設(shè)置Props的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • 解決Element-ui radio單選框label布爾/數(shù)值的一個(gè)坑

    解決Element-ui radio單選框label布爾/數(shù)值的一個(gè)坑

    這篇文章主要介紹了解決Element-ui radio單選框label布爾/數(shù)值的一個(gè)坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 在Vue中使用mockjs代碼實(shí)例

    在Vue中使用mockjs代碼實(shí)例

    這篇文章主要介紹了在Vue中使用mockjs代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • 利用vue+elementUI實(shí)現(xiàn)部分引入組件的方法詳解

    利用vue+elementUI實(shí)現(xiàn)部分引入組件的方法詳解

    這篇文章主要給大家介紹了關(guān)于利用vue+elementUI實(shí)現(xiàn)部分引入組件的相關(guān)資料,以及介紹了vue引入elementUI報(bào)錯(cuò)的解決方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • vue單個(gè)元素綁定多個(gè)事件問題(例如點(diǎn)擊綁定多個(gè)事件方法)

    vue單個(gè)元素綁定多個(gè)事件問題(例如點(diǎn)擊綁定多個(gè)事件方法)

    這篇文章主要介紹了vue單個(gè)元素綁定多個(gè)事件問題(例如點(diǎn)擊綁定多個(gè)事件方法),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04

最新評(píng)論