国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

elementUI中的el-table表頭和內(nèi)容全部一行顯示完整

這篇具有很好參考價值的文章主要介紹了elementUI中的el-table表頭和內(nèi)容全部一行顯示完整。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

項目上有一個需求,需要用el-table來顯示數(shù)據(jù),有一個要求就是不能換行。表頭不能換行,表格里面的內(nèi)容也不能換行。

同事寫的頁面使用的是vue3,自定義了一個事件來動態(tài)變化每一列的參數(shù)。我將其挪用到vue2中完全沒法使用。只能在網(wǎng)上查找資料來實現(xiàn)它。

表格通過接口來獲取,接口中將表頭標題和表格內(nèi)容分開來的。

基本思路就是:表格內(nèi)容限制不換行,不使用縮略符號。

首先從表頭開始,在el-table-column中有一個render-header

    // 表頭部重新渲染
		renderHeader(h, { column, $index }) {
			// 新建一個 span
			let span = document.createElement('span');
			// 設(shè)置表頭名稱
			span.innerText = column.label;
			// 臨時插入 document
			document.body.appendChild(span);
			// 重點:獲取 span 最小寬度,設(shè)置當前列,注意這里加了 20,字段較多時還是有擠壓,且渲染后的 div 內(nèi)左右 padding 都是 10,所以 +20 。(可能還有邊距/邊框等值,需要根據(jù)實際情況加上)
			column.minWidth = (span.getBoundingClientRect().width) + 40;
            this.headerLableWidth[column.property] = column.minWidth;
			// 移除 document 中臨時的 span
			document.body.removeChild(span);
			return h('span', column.label);
		},

column中有這些標題文字信息,?創(chuàng)建一個span標簽,添加到文檔流中,然后拿到它的寬度,為了多加點寬度,可以額外多加些數(shù)值。代碼中多加了40寬度。為表頭設(shè)置最小寬度。

記錄這一列的最小寬度,當表格內(nèi)容動態(tài)設(shè)置寬度的時候,至少要給定成表頭的寬度。不然表頭會因為沒有內(nèi)容寬度變成0.

    flexColumnWidth(str, arr1, flag = 'max'){
      // str為該列的字段名(傳字符串);tableData為該表格的數(shù)據(jù)源(傳變量);
      // flag為可選值,可不傳該參數(shù),傳參時可選'max'或'equal',默認為'max'
      // flag為'max'則設(shè)置列寬適配該列中最長的內(nèi)容,flag為'equal'則設(shè)置列寬適配該列中第一行內(nèi)容的長度。
      str = str + ''
      let columnContent = ''
      if (!arr1 || !arr1.length || arr1.length === 0 || arr1 === undefined) {
        return
      }
      if (!str || !str.length || str.length === 0 || str === undefined) {
        return
      }
      if (flag === 'equal') {
        // 獲取該列中第一個不為空的數(shù)據(jù)(內(nèi)容)
        for (let i = 0; i < arr1.length; i++) {
          if (arr1[i][str].length > 0) {
            // console.log('該列數(shù)據(jù)[0]:', arr1[0][str])
            columnContent = arr1[i][str]
            break
          }
        }
      } else {
        // 獲取該列中最長的數(shù)據(jù)(內(nèi)容)
        let index = 0
        for (let i = 0; i < arr1.length; i++) {
          if (arr1[i][str] === null) {
            return
          }
          const now_temp = arr1[i][str] + ''
          const max_temp = arr1[index][str] + ''
          if (now_temp.length > max_temp.length) {
            index = i
          }
        }
        columnContent = arr1[index][str]
      }
      // console.log('該列數(shù)據(jù)[i]:', columnContent)
      // 以下分配的單位長度可根據(jù)實際需求進行調(diào)整
      let flexWidth = 0
      for (const char of String(columnContent)) {
        if ((char >= 'A' && char <= 'Z') || (char >= 'a' && char <= 'z')) {
          // 如果是英文字符,為字符分配8個單位寬度
          flexWidth += 10
        } else if (char >= '\u4e00' && char <= '\u9fa5') {
          // 如果是中文字符,為字符分配15個單位寬度
          flexWidth += 18
        } else {
          // 其他種類字符,為字符分配8個單位寬度
          flexWidth += 10
        }
      }
      if (flexWidth < this.headerLableWidth[str]) {
        // 設(shè)置最小寬度
        flexWidth = this.headerLableWidth[str]
      }
      // if (flexWidth > 250) {
      //   // 設(shè)置最大寬度
      //   flexWidth = 250
      // }
      // console.log(flexWidth)
      return flexWidth + 'px'
    }
  }

el-table-column標簽中的width使用函數(shù)方法來代替。

完整的el-table如下

        <el-table 
          :ref='tableRef'
          :data="certRecordInfos"
          border
          :fit="true"
          style="width: 100%">
          <el-table-column
            align="center"
            :render-header="renderHeader"
            :width="flexColumnWidth(item.key,certRecordInfos)"
            :key="item.key" 
            :prop="item.key"  
            :label="item.value" >
          </el-table-column>
        </el-table>

因為需要先獲取到表頭的最小寬度,因此需要先加載表頭,才能確保后面加載表格內(nèi)容的時候,能正確的設(shè)置寬度。

在watch中,觀察這兩個數(shù)組,當發(fā)現(xiàn)變化的時候,去重新刷新這個table

    certHeaderList: {
      deep: true,
      handler: function (val) {
        this.$nextTick(() => {
          this.$refs[`${this.tableRef}`].doLayout();
        })
      }
    },
    certRecordInfos: {
      deep: true,
      handler: function (val) {
        this.$nextTick(() => {
          this.$refs[this.tableRef].doLayout();
        })
      }
    }
        this.certHeaderList.splice(0)
        this.certRecordInfos.splice(0)
        const resultHeader = val[0].header
        resultHeader.forEach((header)=>{
          let map = {key:header.columnName,value:header.columnDesc};
          this.certHeaderList.push(map);
        });
        setTimeout(() => {
          const resultList = val[0].list
          this.certRecordInfos.push(...resultList)
        }, 1000);

要實現(xiàn)效果,必須要確保已經(jīng)拿到了表格每一列表頭的最小寬度。并使用headerLableWidth記錄下來。

另外,需要為表格內(nèi)容進行設(shè)置,確保內(nèi)容不會進行換行和使用縮略符號。文章來源地址http://www.zghlxwxcb.cn/news/detail-472082.html

/deep/ .el-table th, .el-table td {
  white-space: nowrap;
}

/deep/ .el-table .cell {
  display: inline-block;
  white-space: nowrap;
  width: auto;
  overflow: auto;
}

/deep/ .el-table .el-table__body-wrapper {
  overflow-x: auto;
}

到了這里,關(guān)于elementUI中的el-table表頭和內(nèi)容全部一行顯示完整的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包