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
      }
    }
  }
}
···
相关推荐
艾小逗3 小时前
vue3中的effectScope有什么作用,如何使用?如何自动清理
前端·javascript·vue.js
小小小小宇5 小时前
手写 zustand
前端
Hamm6 小时前
用装饰器和ElementPlus,我们在NPM发布了这个好用的表格组件包
前端·vue.js·typescript
明似水6 小时前
Flutter 弹窗队列管理:支持优先级的线程安全通用弹窗队列系统
javascript·安全·flutter
小小小小宇7 小时前
前端国际化看这一篇就够了
前端
大G哥7 小时前
PHP标签+注释+html混写+变量
android·开发语言·前端·html·php
whoarethenext7 小时前
html初识
前端·html
小小小小宇7 小时前
一个功能相对完善的前端 Emoji
前端
m0_627827527 小时前
vue中 vue.config.js反向代理
前端
Java&Develop7 小时前
onloyoffice历史版本功能实现,版本恢复功能,编辑器功能实现 springboot+vue2
前端·spring boot·编辑器