给一个字符中的img标签添加图片预览功能,Vant组件、ref和querySelector两种方式实现

139 篇文章 1 订阅
71 篇文章 0 订阅

Vant安装过程点击进入查看

app.vue中的代码如下:

<template>
  <div ref="box" class="box" v-html="imageText"></div>
</template>
<script setup>
import { showImagePreview } from 'vant';
import {onMounted, ref} from "vue";
// 给一段文本字符串的html
const imageText = ref(`<div class="box">
    <img style="width: 100%" src="https://fastly.jsdelivr.net/npm/@vant/assets/apple-1.jpeg" alt="">
    <img style="width: 100%" src="https://fastly.jsdelivr.net/npm/@vant/assets/apple-2.jpeg" alt="">
  </div>`)

// 方式一 querySelector方式
onMounted(()=>{
  const box = document.querySelector('.box');
  console.log('box', box)
  // const image_list = box.value.querySelectorAll('img')
  const image_list = box.querySelectorAll('img')
  const images = []
  image_list.forEach((item,index)=>{
    images.push(item.src)
    item.onclick = ()=>{
      showImagePreview({
        images,
        startPosition: index
      })
    }
  })
})

// 方式二 ref方式
// const box = ref(null)
// onMounted(()=>{
//   const image_list = box.value.querySelectorAll('img')
//   const images = []
//   image_list.forEach((item,index)=>{
//     images.push(item.src)
//     item.onclick = ()=>{
//       showImagePreview({
//         images,
//         startPosition: index
//       })
//     }
//   })
// })
</script>

<style scoped lang="less">

</style>

效果如下:

未点击时:

在这里插入图片描述

点击完后

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值