添加复制id
This commit is contained in:
@@ -115,6 +115,9 @@
|
||||
<el-button @click="dialogAllocation = true">
|
||||
<Icon icon="ep:refresh" class="mr-5px" /> {{ t('newHosts.allocation') }}
|
||||
</el-button>
|
||||
<el-button @click="exportAi">
|
||||
<Icon icon="ep:copy-document" class="mr-5px" /> {{ $t('employee.exportAi') }}
|
||||
</el-button>
|
||||
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
@@ -540,6 +543,51 @@ function changeCountry(region) {
|
||||
|
||||
})
|
||||
}
|
||||
|
||||
function exportAi() {
|
||||
if (selectHostList.value.length === 0) {
|
||||
ElMessage.error('请选择主播')
|
||||
return
|
||||
}
|
||||
|
||||
const data = selectHostList.value.map(item => item.hostsId).join('\n')
|
||||
|
||||
const copyToClipboard = async (text) => {
|
||||
// 优先使用 Clipboard API
|
||||
if (navigator.clipboard && window.isSecureContext) {
|
||||
try {
|
||||
await navigator.clipboard.writeText(text)
|
||||
ElMessage.success('✅ 复制成功 ' + selectHostList.value.length + ' 条数据')
|
||||
} catch (err) {
|
||||
ElMessage.error('❌ 复制失败')
|
||||
console.error(err)
|
||||
}
|
||||
} else {
|
||||
// fallback 兼容方案
|
||||
const textarea = document.createElement('textarea')
|
||||
textarea.value = text
|
||||
textarea.style.position = 'fixed' // 避免跳动
|
||||
textarea.style.opacity = '0'
|
||||
document.body.appendChild(textarea)
|
||||
textarea.select()
|
||||
try {
|
||||
const result = document.execCommand('copy')
|
||||
if (result) {
|
||||
ElMessage.success('✅(兼容模式)复制成功 ' + selectHostList.value.length + ' 条数据')
|
||||
} else {
|
||||
ElMessage.error('❌(兼容模式)复制失败')
|
||||
}
|
||||
} catch (err) {
|
||||
ElMessage.error('❌(兼容模式)复制异常')
|
||||
console.error(err)
|
||||
} finally {
|
||||
document.body.removeChild(textarea)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
copyToClipboard(data)
|
||||
}
|
||||
// /** 初始化 **/
|
||||
// onMounted(() => {
|
||||
// getList()
|
||||
|
||||
Reference in New Issue
Block a user