2

在做一个项目,需要从 wordpress 中通过 wp-json 接口获取 post 内容,然后用 v-html 显示出来,显示出来的内容中,图片大小都只有 300px 宽,原始图片较大,包含更多细节,因此希望能够实现点击放大查看图片细节。

仔细看了一下 post 内容的 html 代码中 img 元素本身的 src 属性指向的图片是 wordpress 经过缩放之后的图片,宽度只有 300px,细节丢失也较严重,同时这些 img 元素都有一个 srcset 属性,这个属性主要是用来在不同的移动设备中显示不同分辨率图片的,包含了不同分辨率的图片地址,因此想到能够通过这个属性来显示大图片。

下面是相关 directive 的代码 SrcSet.js:

export default {
  update (el) {
    el.querySelectorAll('img[srcset]').forEach(i => {
      i.style.cursor = 'url(), auto'

      let srcset = i.attributes.getNamedItem('srcset').value
      let originalSrc = srcset && srcset.split(', ').map(src => (src.split(' ')[0])).pop()
      if (originalSrc) {
        let img = new window.Image()
        img.src = originalSrc
        img.style.position = 'fixed'
        img.style.left = img.style.top = '5%'
        img.style.maxWidth = img.style.maxHeight = '90%'
        img.style.zIndex = 10086
        img.style.cursor = 'url(), auto'

        img.addEventListener('click', () => {
          document.body.removeChild(img)
        })

        i.addEventListener('click', () => {
          document.body.appendChild(img)
        })
      }
    })
  }
}

然后在 main.js 中引入并注册 directive:

import SrcSet from './SrcSet'
Vue.directive('srcset', SrcSet)

最后,在需要用到的地方,添加 v-srcset 指令 <div class="m-b-lg" v-html="post.content" v-srcset></div>

效果:

原 post 内容:
clipboard.png

点击图片后:
clipboard.png


KingMario
7.2k 声望519 粉丝

《学习 Vue 你需要知道的 webpack 知识》[链接]