使用elementplus实现文本框的粘贴复制

需求:

文本框仅用于显示展示数据并且用户可以进行复制,并不会进行修改和编辑,

注意点:

1.首先且文本为多行。所以不能使用普通的el-input,这种一行超出就会隐藏了,如果多行超出行数也会隐藏(或者显示...,或者需要设置滚动条),应该加一个 type='textarea'即可
<el-input type='textarea' />

2.文本框仅作展示数据,普通情况下是可以输入的,不可以用disabled关键字禁止输入,这样一上去会有个标号,只需要用 readonly关键字就好<el-input type='textarea' readonly/>

3.对于复制的图标,应该放在文本内部的右上方。我试过后缀:<el-input type='textarea' readonly suffix-icon="el-icon-search"/>,但是似乎只对文本框起作用,对于textarea类型的没有作用位置。接着我尝试嵌入,也就是

js 复制代码
import { DocumentCopy } from '@element-plus/icons-vue'
<template>
	<div>
		<el-input type='textarea'  readonly>
			<el-icon> <DocumentCopy /></el-icon>
		</el-input>
	</div>
<template>

但是仍然不起作用

4.最后还是通过同级的方式

js 复制代码
import { DocumentCopy } from '@element-plus/icons-vue'
<template>
	<div>
		<el-input type='textarea'  readonly></el-input>
		<el-icon> <DocumentCopy /></el-icon>
	</div>
</template>

5.这样能看到图标了,只不过在文本框的左下角

6.然后现在要做的就是移动到el-input里面的右上角,先移动到右边:float:right。

因为是兄弟元素,相当于在空间上是同一层, 解决方案是设置z-index:999;,是的el-icon在上层(后面经过测试可以不要,因为不存在动画覆盖问题)

7.为了移动到内部的上面,使用定位,如果使用fixed是固定定位,是相对于整个窗口的,倘若窗口进行缩放可能设置的margin-right就会跟着变,所以应该使用相对定位,相对于父元素div

js 复制代码
import { DocumentCopy } from '@element-plus/icons-vue'
<template>
	<div style="position:relative">
		<el-input type='textarea'  readonly></el-input>
		<el-icon style="float: right; position: absolute; right:10px; top: 10px"> <DocumentCopy /></el-icon>
	</div>
</template>

8.这样UI部分就完成了,效果如下:

绑定事件

我在搜索的过程中发现有些推荐了一个库vue-clipboard3,作为事件的复制,可以参考下面:

https://blog.csdn.net/LeoForBest/article/details/121581831

在npm官网查看包的使用:https://www.npmjs.com/package/vue-clipboard3

逻辑代码就是这样:

js 复制代码
<template>
	<div style="position:relative">
		<el-input type='textarea' v-model="sourceAnswer" :autosize="{ minRows: 12, maxRows: 16 }" placeholder="the answer will be there"  readonly></el-input>
		<el-icon @click="copyAnswer(sourceAnswer)" style="float: right; position: absolute; right:10px; top: 10px"> <DocumentCopy /></el-icon>
	</div>
</template>

<script setup>
import { DocumentCopy } from '@element-plus/icons-vue'
import { ElMessage } from 'element-plus'
import useClipboard from 'vue-clipboard3'
const { toClipboard } = useClipboard()
const sourceAnswer = ref('这是测试的文本')

const copyAnswer = async(copyData) => {
  console.log('copyData',copyData)
  if (copyData === '') {
    ElMessage.warning('请输入文本再复制');
    return
  }
  try {
    await toClipboard(copyData)
    ElMessage.success(`复制: ${copyData} 成功!`);
  } catch (error) {
    ElMessage.warning(`复制失败: ${error} !`);
    console.error(error)
  }
}
<script setup>

测试结果如下:

ctrl+c也可以粘贴在控制台上

样式就自己写和改啦~

相关推荐
Yolanda9417 小时前
【项目经验】钉钉免密登录实现
前端·javascript·钉钉
2601_9496130217 小时前
flutter_for_openharmony家庭药箱管理app实战+药品详情实现
java·前端·flutter
摘星编程17 小时前
在OpenHarmony上用React Native:collapsable节点优化策略
javascript·react native·react.js
We་ct18 小时前
LeetCode 15. 三数之和:排序+双指针解法全解析
前端·算法·leetcode·typescript
美狐美颜SDK开放平台18 小时前
直播场景下抖动特效的实现方案:美颜sdk开发经验分享
前端·人工智能·美颜sdk·直播美颜sdk·视频美颜sdk
Beginner x_u18 小时前
JavaScript 原型、原型链与原型继承的核心机制解析
开发语言·javascript·原型模式·原型原型链
草青工作室18 小时前
java-FreeMarker3.4自定义异常处理
java·前端·python
美狐美颜sdk18 小时前
抖动特效在直播美颜sdk中的实现方式与优化思路
前端·图像处理·人工智能·深度学习·美颜sdk·直播美颜sdk·美颜api
Mr Xu_18 小时前
Vue3 + Element Plus 实战:App 版本管理后台——动态生成下载二维码与封装文件上传
前端·javascript·vue.js
闻哥18 小时前
从 AJAX 到浏览器渲染:前端底层原理与性能指标全解析
java·前端·spring boot·ajax·okhttp·面试