前端解决微信公众号图片引用错误

问题出现

项目有一个功能为导入微信文章, 查看导入文章是发现图片加载错误, 如下:
在这里插入图片描述

解决:

在网上搜索,前端,大致有以下3种解决方式:

1.添加meta标签, 这种方法试了 无效

 <meta name="referrer" content="never">

2.添加采集图片链接, 这种方法测试也 无效
在这里插入图片描述
3. 使用iframe 解决, 这种试了 有效, 以下是我的代码( vue )

function showImg(url, i) {
  var frameid = "frameimg" + Math.random();
  window[`img_${i}`] =
    '<img id="' +
    `mock_wx_article_img_${i}` +
    '" style="display:block;max-width:100%;margin:0 auto;" src=\'' +
    url +
    "?" +
    Math.random() +
    "' /><script>window.onload = function() { parent.document.getElementById('" +
    frameid +
    "').height = document.getElementById(\"" +
    `mock_wx_article_img_${i}` +
    "\").height+'px'; }<" +
    "/script>";

  let iframeHtml =
    '<iframe id="' +
    frameid +
    '" style="width:100%;" src="javascript:parent.' +
    `img_${i}` +
    ';" frameBorder="0" scrolling="no"></iframe>';
  return iframeHtml;
}

const changeToShowWxImg = function(html) {
  let mockDiv = document.createElement("div");
  mockDiv.setAttribute("id", "mock_wx_article_div");
  mockDiv.setAttribute("style", "opacity: 0;");
  mockDiv.innerHTML = html;
  document.body.appendChild(mockDiv);

  let imgList = mockDiv.querySelectorAll("img");
  imgList = [...imgList];

  try {
    imgList.forEach((node, i) => {
      let img_src = node.getAttribute("src");
      let div = document.createElement("div");
      div.innerHTML = showImg(img_src, i);
      node.parentNode.appendChild(div);
      node.parentNode.removeChild(node);
    });
    let new_wx_article_content = mockDiv.innerHTML;
    document.body.removeChild(mockDiv);
    return new_wx_article_content;
  } catch (e) {
    console.log(e);
    return html;
  }
};

export default changeToShowWxImg;

将后台返回的content 转化 成新的html, 在通过 v-html 插入 .

PS: 如有其它方法,请不吝赐教, 十分感谢

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值