小程序地图组件(map)中使用全屏预览图片(previewImage)的问题解决方案

小程序地图组件(map)中使用全屏预览图片(previewImage)的问题解决方案

背景

在小程序中 Map 组件中使用 previewImage 预览图片,无法在地图组件上预览图片,如果返回到上一页 previewImage 方法才会打开预览图片。

因为 map 组件是原生组件,层级默认最高,会覆盖在 WebView 之上。由于原生组件的隔离性,可能导致 previewImage 的调用被阻塞或延迟执行。

解决方案

方案一:弹窗打开预览图片

在地图组件上使用 cover-viewcover-image 等标签通过弹窗事项图片预览。

预览图片弹窗组件 使用 taro 框架为例: map 组件内的

index.jsx

jsx 复制代码
import { View, Swiper, SwiperItem, Image } from '@tarojs/components';
import classNames from 'classnames';

import styles from './index.module.scss';

const MapPreviewImage = (props) => {
  const { visible, onClose, images = [], current = 0 } = props;

  return (
    <View className={classNames(styles.imageModal, { [styles.visible]: visible })} onClick={onClose} catchMove>
      <Swiper
        current={current}
        className={styles.swiper}
        indicator-dots
        indicator-color="#fff"
        indicator-active-color="#DB5545"
      >
        {images?.map?.((image) => (
          <SwiperItem key={image} className={styles.swiperItem}>
            <View className={styles.imageWrapper}>
              <Image
                className={styles.image}
                mode="widthFix"
                src={image}
                onClick={(e) => {
                  e.stopPropagation();
                  e.preventDefault();
                }}
              />
            </View>
          </SwiperItem>
        ))}
      </Swiper>
    </View>
  );
};

export default MapPreviewImage;

index.module.scss

scss 复制代码
.image-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 100;
  transition: all 0.3s ease-in-out;
  display: none;
  background-color: #000;

  &.visible {
    display: block;
  }

  .swiper {
    width: 100%;
    height: 100%;
  }

  .swiper-item {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .image-wrapper {
    width: 100%;
    height: auto;
  }
}

使用预览图片弹窗组件 indx.jsx

javascript 复制代码
import { View, Map } from '@tarojs/components';
import MapPreviewImage from '../MapPreviewImage';

const Index = () => {
 const [visible, setVisible] = useState(false);
 const [previewImages, setPreviewImages] = useState([]); // img url

  return (
      <Map style={{height: '100vh'}} {...地图属性}>
        <View onClick={() => setVisible(true)}>打开弹窗</View>
          
        <MapPreviewImage 
            visible={visible} 
            onClose={() => setVisible(false)} 
            images={previewImages} />
      </Map>
  );
}

export default Index;

方案二:调整到新页面使用 previewImage 方法预览图片

  1. 定义一个新页面,props 需要有 previewImageurls; 在 useEefft 或者小程序的生命周期内调用 previewImage 方法打开预览图片;
  2. Map 组件页面,触发事件,跳转到预览图片页面并带需要的参数
  3. 此方案不具体赘述,不提供代码

注意事项

  1. Map 组件中的 View 使用 onClick 方法会有延迟,或可以使用 onTouchStart
  2. Map 组件内的其他元素滑动会带动地图滑动,可在元素上添加 catchMove 属性。
相关推荐
陈随易3 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星3 小时前
javascript之事件代理/事件委托
前端
陈随易5 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
里欧跑得慢7 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒7 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
kyriewen7 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真8 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal8 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
竹林8188 小时前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding8 小时前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化