饮品专家 發表於 2025-11-6 11:30:00

vxe-table 复制单元格时如何自定义内容,自定义复制的文本内容

<p>vxe-table 复制单元格时如何自定义内容,自定义复制的文本内容<br>
默认情况下是复制对应 field 字段值,当需要对特定字段进行格式化或自定义时,就可以通过 copyMethod、pasteMethod 配置可以精确控制复制粘贴的所有行为以及自定义复制粘贴的逻辑控制。比如需要控制某个单元格复制后的值,本来是下拉框的键值,要转成实际值复制到 excel,这时候就可以使用该转换函数了</p>
<p>查看官网:https://vxetable.cn</p>
<p><img src="https://img2024.cnblogs.com/blog/3563285/202511/3563285-20251106112934505-1584327481.png"></p>
<pre><code class="language-html">&lt;template&gt;
&lt;div&gt;
    &lt;vxe-grid v-bind="gridOptions"&gt;&lt;/vxe-grid&gt;
&lt;/div&gt;
&lt;/template&gt;

&lt;script setup&gt;
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 = cellValue ? (cellValue === '男' ? '1' : '0') : ''
      } else {
          row = 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号' }
]
})
&lt;/script&gt;
</code></pre><br><br>
来源:https://www.cnblogs.com/qaz666/p/19196101
頁: [1]
查看完整版本: vxe-table 复制单元格时如何自定义内容,自定义复制的文本内容