动态

详情 返回 返回

vxe-table 複製單元格時如何自定義內容,自定義複製的文本內容 - 动态 详情

vxe-table 複製單元格時如何自定義內容,自定義複製的文本內容
默認情況下是複製對應 field 字段值,當需要對特定字段進行格式化或自定義時,就可以通過 copyMethod、pasteMethod 配置可以精確控制複製粘貼的所有行為以及自定義複製粘貼的邏輯控制。比如需要控制某個單元格複製後的值,本來是下拉框的鍵值,要轉成實際值複製到 excel,這時候就可以使用該轉換函數了

查看官網:https://vxetable.cn

image

<template>
  <div>
    <vxe-grid v-bind="gridOptions"></vxe-grid>
  </div>
</template>

<script setup>
import { reactive } from 'vue'

const sexEditRender = reactive({
  name: 'VxeSelect',
  options: [
    { label: '女', value: '0' },
    { label: '男', value: '1' }
  ]
})

const gridOptions = reactive({
  border: true,
  height: 500,
  showOverflow: true,
  columnConfig: {
    resizable: true
  },
  mouseConfig: {
    area: true // 是否開啓區域選取
  },
  areaConfig: {
    multiple: true // 是否啓用多區域選取功能
  },
  editConfig: {
    mode: 'cell', // 單元格編輯模式
    trigger: 'dblclick' // 雙擊單元格激活編輯狀態
  },
  keyboardConfig: {
    isAll: true, // 是否啓用快捷鍵全選
    isClip: true, // 是否開啓複製粘貼
    isEdit: true, // 是否開啓任意鍵進入編輯(功能鍵除外)
    isDel: true, // 是否開啓刪除鍵功能
    isEsc: true // 是否開啓Esc鍵關閉編輯功能
  },
  columns: [
    { type: 'seq', fixed: 'left', width: 60 },
    { field: 'name', fixed: 'left', title: '名字', editRender: { name: 'input' } },
    {
      field: 'role',
      title: '角色',
      editRender: { name: 'input' },
      copyMethod ({ cellValue }) {
        return `角色:${cellValue}`
      }
    },
    {
      field: 'sex',
      title: '性別',
      editRender: sexEditRender,
      copyMethod ({ column, cellValue }) {
        // 對於下拉框的類型,自定義指定列的複製內容
        if (column.field === 'sex') {
          return cellValue ? (cellValue === '1' ? '男' : '女') : ''
        }
        return cellValue
      },
      pasteMethod ({ row, column, cellValue }) {
        // 對於下拉框的類型,自定義指定列粘貼邏輯
        if (column.field === 'sex') {
          row[column.field] = cellValue ? (cellValue === '男' ? '1' : '0') : ''
        } else {
          row[column.field] = cellValue
        }
      }
    },
    { field: 'num', title: '分數', editRender: { name: 'VxeNumberInput' } },
    { field: 'age', title: '年齡', editRender: { name: 'VxeNumberInput' } },
    { field: 'address', title: '地址', width: 200, editRender: { name: 'input' } }
  ],
  data: [
    { id: 10001, name: '張三', role: '前端開發', sex: '0', num: 23, age: 28, address: '北京市17號' },
    { id: 10002, name: '李四', role: '測試人員', sex: '1', num: 23, age: 22, address: '江蘇省27號' },
    { id: 10003, name: '老六', role: '項目經理', sex: '0', num: 23, age: 32, address: '深圳市19號' },
    { id: 10004, name: '小李', role: '後端開發', sex: '1', num: 456, age: 24, address: '江蘇省47號' },
    { id: 10005, name: '老萬', role: '設計師', sex: '1', num: 23, age: 42, address: '北京市18號' },
    { id: 10006, name: '小劉', role: '前端開發', sex: '0', num: 23, age: 38, address: '上海市17號' },
    { id: 10007, name: '老徐', role: '測試人員', sex: '1', num: 100, age: 24, address: '北京市19號' },
    { id: 10008, name: '老二', role: '設計師', sex: '0', num: 345, age: 34, address: '上海市11號' },
    { id: 10009, name: '小牛', role: '前端開發', sex: '1', num: 67, age: 52, address: '深圳市29號' },
    { id: 10010, name: '小帥', role: '測試人員', sex: '1', num: 23, age: 44, address: '北京市37號' },
    { id: 10011, name: '老魏', role: '後端開發', sex: '0', num: 56, age: 52, address: '深圳市12號' },
    { id: 10012, name: '小徐', role: '測試人員', sex: '1', num: 23, age: 16, address: '廣州市16號' },
    { id: 10013, name: '小張', role: '設計師', sex: '1', num: 69, age: 16, address: '廣州市46號' },
    { id: 10014, name: '老馮', role: '前端開發', sex: '0', num: 36, age: 36, address: '廣州市66號' },
    { id: 10015, name: '小哥', role: '後端開發', sex: '0', num: 33, age: 47, address: '廣州市56號' },
    { id: 10016, name: '李哥', role: '測試人員', sex: '1', num: 2, age: 42, address: '深圳市16號' }
  ]
})
</script>
user avatar freeman_tian 头像 dirackeeko 头像 huajianketang 头像 banana_god 头像 dunizb 头像 kitty-38 头像 romanticcrystal 头像 tanggoahead 头像 yulong1992 头像 xw-01 头像 abc-x 头像 geeklab 头像
点赞 69 用户, 点赞了这篇动态!
点赞

Add a new 评论

Some HTML is okay.