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
      }
    }
  }
}
···
相关推荐
Clownseven2 小时前
[Web服务器对决] Nginx vs. Apache vs. LiteSpeed:2025年性能、功能与适用场景深度对比
服务器·前端·nginx
TE-茶叶蛋3 小时前
React的合成事件(SyntheticEventt)
前端·javascript·react.js
GISer_Jing5 小时前
CSS-in-JS:现代前端样式管理的革新
前端·javascript·css
咖啡の猫7 小时前
JavaScript基础-作用域链
开发语言·javascript
2501_914286497 小时前
Web技术与Nginx网站环境部署
前端·nginx·php
啊啊啊~~7 小时前
css实现不确定内容的高度过渡
前端·javascript·css
tongjiwenzhang7 小时前
APPtrace 智能参数系统:重构 App 用户增长与运营逻辑
大数据·前端·重构
亲爱的马哥8 小时前
TDuckX 2.6 正式发布|API 能力开放,核心表单逻辑重构,多项实用功能上线。
java·服务器·前端
Raink老师8 小时前
制作大风车动画
前端·harmonyos·鸿蒙·案例实战
追求者20168 小时前
实现图片自动压缩算法,canvas压缩图片方法
前端·javascript·canvas