同時改變兩個表格的寬 element ui

這是我參與8月更文挑戰的第9天,活動詳情查看:  8月更文挑戰html

學習過程當中將筆記跟你們分享,但願對你們也有所幫助,共同成長進步💪~
若是你們喜歡,能夠點贊或留言💕~~~~,謝謝你們⭐️⭐️⭐️~~~vue

需求是兩個表格,改變其中一個表格列的寬,另外一個表格也隨之相應改變同等寬度。本文是用的vue+element ui框架。 文中使用header-dragend方法,官網有介紹:當拖動表頭改變了列的寬度的時候會觸發該事件 image.png 具體代碼以下:web

<el-table :data="tableData" border @header-dragend="headerdragend" style="width: 100%">
      <el-table-column v-for="column in tableTitleList" :fixed="column.fixed" :prop="column.prop" :label="column.label" :width="column.width">
      </el-table-column>
      <el-table-column fixed="right" label="操做" width="100">
        <template slot-scope="scope">
          <el-button @click="handleClick(scope.row)" type="text" size="small">查看</el-button>
          <el-button type="text" size="small">編輯</el-button>
        </template>
      </el-table-column>
    </el-table>
    <hr>
    <el-table :data="tableData" border @header-dragend="headerdragend" style="width: 100%">
      <el-table-column v-for="column in tableTitleList" :fixed="column.fixed" :prop="column.prop" :label="column.label" :width="column.width">
      </el-table-column>
      <el-table-column fixed="right" label="操做" width="100">
        <template slot-scope="scope">
          <el-button @click="handleClick(scope.row)" type="text" size="small">查看</el-button>
          <el-button type="text" size="small">編輯</el-button>
        </template>
      </el-table-column>
    </el-table>
複製代碼
methods: {
        handleClick(row) {
          console.log(row);
        },
        headerdragend() {
          top.console.log('headerdragend', arguments)
          var el = arguments[3].target;
          var clist = el.parentNode.parentNode.parentNode.parentNode.children[0].children;
          setTimeout(() => {
            this.tableTitleList.forEach((v, idx) => {
              v.width = (clist[idx] && clist[idx].width) || 'auto'
            })
          }, 100)
        },
}
 data() {
        return {
          tableTitleList: [
            {
              fixed: true,
              prop: "date",
              label: "日期",
              width: "150"
            },
            {
              prop: "name",
              label: "姓名",
              width: "120",
            },
            {
              prop: "province",
              label: "省份",
              width: "120",
            },
            {
              prop: "city",
              label: "市區",
              width: "120",
            },
            {
              prop: "address",
              label: "地址",
              width: "300",
            },
            {
              prop: "zip",
              label: "郵編",
              width: "120",
            },
          ],
          tableData: [{
            date: '2016-05-02',
            name: '王小虎',
            province: '上海',
            city: '普陀區',
            address: '上海市普陀區金沙江路 1518 弄',
            zip: 200333
          }, {
            date: '2016-05-04',
            name: '王小虎',
            province: '上海',
            city: '普陀區',
            address: '上海市普陀區金沙江路 1517 弄',
            zip: 200333
          }, {
            date: '2016-05-01',
            name: '王小虎',
            province: '上海',
            city: '普陀區',
            address: '上海市普陀區金沙江路 1519 弄',
            zip: 200333
          }, {
            date: '2016-05-03',
            name: '王小虎',
            province: '上海',
            city: '普陀區',
            address: '上海市普陀區金沙江路 1516 弄',
            zip: 200333
          }]
        }
      }
複製代碼

效果圖以下:markdown

image.png

image.png

若是你們有更好的方法能夠寫在評論裏供你們參考~~~~ 歡迎閱讀~~~⭐️⭐️⭐️框架

相關文章
相關標籤/搜索