v-html 富文本中图片使用element-ui image-viewer组件实现预览,并且阻止滚动条

效果

导入组件

复制代码
import ElImageViewer from "element-ui/packages/image/src/image-viewer";
components:{ ElImageViewer },

模板使用组件

复制代码
<el-image-viewer
      v-if="isShowPics"
      :on-close="closeViewer"
      :url-list="srcList"
    />

定义两个变量

复制代码
isShowPics:false,
   srcList:[],
在v-html添加点击获取图片
复制代码
<div v-html="newsForm.content" @click="getImg($event)" style="padding-left: 50px;padding-right: 50px;"></div>

两个点击事件,包含预览时滚动异常

复制代码
closeViewer(){
      this.isShowPics = false
      this.srcList = []
      move()
      //取消滑动限制
      function move(){
        var mo=function(e){
          e.preventDefault();
      };
      document.body.style.overflow='';//出现滚动条
      document.removeEventListener("touchmove",mo,false);
    }
    },
    getImg($event){
      let currentSrc=$event.target.currentSrc
      if (currentSrc){
        this.srcList = [currentSrc]
        this.isShowPics = true
        stop()
      }
        //禁止滚动
      function stop(){
        var mo=function(e){
          e.preventDefault();
        };
        document.body.style.overflow='hidden';
        document.addEventListener("touchmove",mo,false);//禁止页面滑动
      }
    },
相关推荐
用户21411832636021 分钟前
02-N8N教程-手把手教你用 PostgreSQL 实现 N8N 数据持久化,生产环境部署实战!
前端
玄玄子2 分钟前
webpack学习指南
前端·webpack·程序员
不爱说话郭德纲4 分钟前
面试官:你给我讲讲async/await
前端·深度学习·面试
前端小巷子5 分钟前
Promise 链式调用:让异步编程更优雅
前端·面试·promise
周日不上发条6 分钟前
前端必学:CSS实现精美渐变色票据组件(含完整源码)
前端
有梦想的攻城狮12 分钟前
从0开始学vue:pnpm怎么安装
前端·javascript·vue.js
pzpcxy52014 分钟前
安装VUE客户端@vue/cli报错警告npm WARN deprecated解决方法 无法将“vue”项识别为 cmdlet、函数
前端·vue.js·npm
醉书生ꦿ℘゜এ15 分钟前
npm error Cannot read properties of null (reading ‘matches‘)
前端·npm·node.js
疯狂的沙粒29 分钟前
uni-app 如何实现选择和上传非图像、视频文件?
前端·javascript·uni-app
Teln_小凯30 分钟前
Python读取阿里法拍网的html+解决登录cookie
开发语言·python·html