vue3+element-push 实现input框粘贴图片或文本,图片上传。

vue3+element-push 实现input框粘贴图片或文本,图片上传。

复制代码
<el-input
          style="height: 100px; width: 100%"
          @paste.capture.prevent="pasting"
          v-model="textMsg"
          placeholder="请输入"
        />
        // 展示上传的列表--可不要
       <div
        style="margin-bottom: 10px; line-height: 20px"
        v-show="filesList"
        v-for="(item, index) in filesList"
        :key="index"
      >
        <div class="zi">
        <img
            :src="item.filePath"
            class="record-img"
            v-if="
              item.fileType === 'png' ||
              item.fileType === 'jpg' ||
              item.fileType === 'jpeg' ||
              item.fileType === 'ico' ||
              item.fileType === 'bmp' ||
              item.fileType === 'gif'
            "
          />
          <img
            src="/src/assets/imgs/fileImg/docx.png"
            class="record-img"
            v-else-if="item.fileType === 'doc' || item.fileType === 'docx'"
          />
          <img
            src="/src/assets/imgs/fileImg/xlsx.png"
            class="record-img"
            v-else-if="item.fileType === 'xls' || item.fileType === 'xlsx'"
          />
          <img
            src="/src/assets/imgs/fileImg/zip.png"
            class="record-img"
            v-else-if="item.fileType === 'zip'"
          />
          <img
            src="/src/assets/imgs/fileImg/rar.png"
            class="record-img"
            v-else-if="item.fileType === 'rar'"
          />
          <img
            src="/src/assets/imgs/fileImg/ppt.png"
            class="record-img"
            v-else-if="item.fileType === 'ppt' || item.fileType === 'pptx'"
          />
          <img
            src="/src/assets/imgs/fileImg/pdf.png"
            class="record-img"
            v-else-if="item.fileType === 'pdf'"
          />
          <img
            src="/src/assets/imgs/fileImg/txt.png"
            class="record-img"
            v-else-if="item.fileType === 'txt'"
          />
          <img
            src="/src/assets/imgs/fileImg/html.png"
            class="record-img"
            v-else-if="item.fileType === 'html'"
          />
          <img src="/src/assets/imgs/fileImg/file.png" class="record-img" v-else />
          <div style="folat: left; margin-left: 40px">
            <el-link
              :href="item.filePath"
              :underline="false"
              download
              target="_blank"
              type="primary"
            >
              {{ item.fileName }}
            </el-link>
          </div>
          <el-icon
            style="position: absolute; right: 20px; top: 7px; color: red"
            size="16"
            @click="deleteFile(index)"
            ><Delete
          /></el-icon>
        </div>
      </div> 
···
···
...
// js部分截图 /
const textMsg = ref('')
const pasting = async (event) => {
  let txt = event.clipboardData.getData('Text')
  if (typeof txt == 'string') {
    textMsg.value += txt
  }
  let cutFile = null
  const items = (event.clipboardData || window.clipboardData).items
  if (items.length) {
    for (let i = 0; i < items.length; i++) {
      if (items[i].type.indexOf('image') !== -1) {
        cutFile = items[i].getAsFile()
        message.success('截图上传中请稍等。。。')
        await FileApi.updateFile({ file: cutFile }).then((res) => {
          filesList.value.push({
            filePath: res.data,
            fileType: cutFile.name.split('.')[1],
            fileName: cutFile.name
          })
        })
        break
      }
    }
  }
}
···
相关推荐
IT_陈寒17 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691518 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔19 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙68720 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen21 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
青山Coding1 天前
Cesium应用(八):物体运动的实现思路
前端·cesium
用户41659673693551 天前
Android WebView 加载 file:// 离线页面调试教程
android·前端
Asmewill1 天前
curl命令学习笔记一
前端
我是一只快乐的小螃蟹1 天前
1.2 ArrayList 源码解析
前端
星栈1 天前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架