• vue项目base64转img


     最近一个vue项目中,有个需求是, 发送消息是base64时,转换成图片预览发送出去。

    输入框:

          <el-input
            class="input-box"
            ref="elInputText"
            type="textarea"
            v-model="content"
            @paste.native="onPasteEvent"
            @keydown.native.enter.prevent="handlerKeyupEnter"
          ></el-input>

    设定一个 dialog 弹框。

        <!-- 图片预览dialog -->
        <el-dialog
          title="图片预览"
          :visible.sync="previewImgObj.show"
          v-if="previewImgObj.show"
          append-to-body
        >
          <img
            width="100%"
            v-if="previewImgObj.imgUrl"
            class="ly-margin-center"
            :src="previewImgObj.imgUrl"
            v-image-view
          />
          <span slot="footer" class="dialog-footer">
            <el-button @click="previewImgObj.show = false">取 消</el- button>
            <el-button type="primary" @click="sendBase64ImgMessge">确 定</el-button>
          </span>
        </el-dialog>
        // 监听粘贴事件
        async onPasteEvent(e) {
          e.preventDefault();
          let data = await addEventPasteListener(e);
    
           if (data.type === "string") {
            // 复制某条消息
            if (!data.string) return;
            // console.log(data.string)
            // 正则表达式判断data是否是base64
            function validDataUrl(s) {
              return validDataUrl.regex.test(s);
            }
            validDataUrl.regex = /^s*data:([a-z]+/[a-z0-9-+.]+(;[a-z-]+=[a-z0-9-]+)?)?(;base64)?,([a-z0-9!$&',()*+;=-._~:@/?%s]*?)s*$/i;
            // 如果是base64转换成图片预览
            if (validDataUrl(data.string)) {
              let that = this;
              function previwImg(item) {
                that.previewImgObj = {
                  show: true,
                  imgUrl: item
                };
              }
              previwImg(data.string);
            }
         }

    效果展示:

     

  • 相关阅读:
    转_前端开发技术概要
    获取链接的参数
    tabIndex 主要是美化tab键切换的体现
    textarea自动增高并隐藏滚动条
    Zen Coding:css,html缩写替换大观让你的html,css飞起来
    动态添加链接颜色代码
    转javascript 数组
    为指定元素增加样式
    1 CodeBox代码盒子 alpha版发布
    转发布js支持Firefox的加入收藏代码
  • 原文地址:https://www.cnblogs.com/lpp-11-15/p/11445521.html
Copyright © 2020-2023  润新知