动态遍历富文本的img标签的src是否是base64(把base64替换成http开头的路径)

// 将base64转换成文件流
自己遇到的问题,领导给了一个任务,需要查看富文本编辑器中的img标签的src是否是base64格式,是的话就需要调接口变成https开头的图片路径替换base64。找了半天没找到类似的,自己总结一下吧 。

 

base64toFile (dataurl) {

// 将base64转换成文件流
      let filename = 'file'
      let arr = dataurl.split(',')
      let mime = arr[0].match(/:(.*?);/)[1]
      let suffix = mime.split('/')[1]
      let bstr = atob(arr[1])
      let n = bstr.length
      let u8arr = new Uint8Array(n)
      while (n--) {
          u8arr[n] = bstr.charCodeAt(n)
      }
      return new File([u8arr], `${filename}.${suffix}`, {
          type: mime
      })
    },

  // 富文本的方法改变返回数据
    onContentChange(val, num) {
      let content = val;
      let imgReg = /<img.*?(?:>|\/>)/gi // 匹配图片中的img标签
      let srcReg = /src=[\'\"]?([^\'\"]*)[\'\"]?/i // 匹配图片中的src
      let arr = content.match(imgReg)  // 筛选出所有的img
      let srcArr = []
      if (arr != null) {
        for (let i = 0; i < arr.length; i++) {
          let src = arr[i].match(srcReg)
          // 获取图片地址判断是否是base64格式
          if (src[1].indexOf('base64') == -1) {
            return
          } else {
            srcArr.push(src[1])
          }
        }
        let formData = new FormData()
        srcArr.forEach(item =>  {
          // 将base64转换成文件流
          formData.append('file', this.base64toFile(item))

        // 这里是上传文件流的接口
          uploadyunfile(formData).then((res) => {
            if (res.code == 200) {
              this.contentValue = content.replace(item, res.data.filePath);

            // 这里有点坑,因为是循环,老是拿不到最新数据,通过watch监听动态赋值。
            }
          }).catch((res) => {
            
          })
        })
      }
      this.wordslength = num;
      this.ruleForm.intro = content;
      this.debounce(3000, ["intro", val]);
    },
  // 动态监听并赋值
   watch: {
     contentValue(val) {
      if (val) {

      监听动态赋值
        this.ruleForm.intro = val;
      }
    }
  }

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值