小程序地图组件(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 属性。
相关推荐
前端九哥6 小时前
老板:就是你小子删光了try-catch?
前端·javascript
杰出的胡兵6 小时前
2v1带您实战12nm高级数字后端
前端·soc·数字后端·数字ic后端·芯片设计全流程培训
Achieve前端实验室6 小时前
深入浅出 ES Module
前端·javascript·前端框架
Onion6 小时前
BroadcastChannel 使用:优缺点、场景示例与最佳实践
前端·javascript
东东2336 小时前
搭建 Vite + React 服务端渲染(SSR)环境
前端·javascript·react.js
上车函予6 小时前
点击即扩散:使用 View Transition API 实现 UnoCSS 官网同款主题切换动画
前端·javascript·css
星链引擎6 小时前
生成式 AI 驱动下的智能聊天机器人 技术架构核心实现与场景落地
前端
Asort6 小时前
React框架深度剖析:设计理念、核心机制与现代生态对比
前端·javascript·react.js
charlie1145141916 小时前
从模仿到掌握:尝试一下Native CSS手写一个好看的按钮
前端·css·学习·ui