欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > 微信小程序地图案例

微信小程序地图案例

2025/4/3 14:16:39 来源:https://blog.csdn.net/qq_60597540/article/details/139722409  浏览:    关键词:微信小程序地图案例

微信小程序作为一种轻量级应用开发平台,广泛应用于各类服务场景中。今天我们将通过一个实际案例,演示如何在微信小程序中实现“查看附近美食餐厅”的功能。

项目概述
我们将开发一个微信小程序,用户可以通过该程序查看自己当前位置附近的美食餐厅,并在地图上显示这些餐厅的位置。点击地图上的标记,可以查看餐厅的详细信息。

功能需求 获取用户当前位置 显示带有当前定位的地图 查询并显示附近的美食餐厅 点击餐厅标记查看餐厅详情 开发步骤

  1. 初始化项目 首先,在微信开发者工具中创建一个新的小程序项目,并配置好基本文件结构:
  • pages/
    • index/
      • index.wxml
      • index.js
      • index.wxss
      • index.json
    • restaurant/
      • restaurant.wxml
      • restaurant.js
      • restaurant.wxss
      • restaurant.json
  • cloudfunctions/
    • getNearbyRestaurants/
      • index.js
      • package.json
  • app.json
  • app.js
  • app.wxss
  1. 配置路由 (app.json)
    在 app.json 中添加页面路径配置:

json

{"pages": ["pages/index/index","pages/restaurant/restaurant"],"window": {"navigationBarBackgroundColor": "#ffffff","navigationBarTextStyle": "black","navigationBarTitleText": "附近美食","backgroundColor": "#eeeeee","backgroundTextStyle": "light"}
}
  1. 创建主页界面 (index.wxml)
    在 pages/index/index.wxml 中,我们将使用地图组件来展示地图,并添加一个按钮用于获取附近餐厅:

xml

<view class="container"><map id="map" longitude="{{longitude}}" latitude="{{latitude}}" show-location markers="{{markers}}" bindmarkertap="onMarkerTap"style="width: 100%; height: 500px;"></map><button bindtap="getNearbyRestaurants">查看附近美食</button>
</view>
  1. 实现主页逻辑 (index.js)
    在 pages/index/index.js 中,我们需要实现获取当前位置和查询附近餐厅的功能:

javascript

Page({data: {latitude: 0,longitude: 0,markers: []},onLoad: function() {this.getLocation();},getLocation: function() {wx.getLocation({type: 'gcj02',success: (res) => {this.setData({latitude: res.latitude,longitude: res.longitude});this.getNearbyRestaurants(); // 自动加载附近餐厅},fail: () => {wx.showToast({title: '无法获取地理位置',icon: 'none'});}});},getNearbyRestaurants: function() {wx.cloud.callFunction({name: 'getNearbyRestaurants',data: {latitude: this.data.latitude,longitude: this.data.longitude},success: (res) => {const restaurants = res.result.data;const markers = restaurants.map((restaurant, index) => ({id: index,latitude: restaurant.location.latitude,longitude: restaurant.location.longitude,title: restaurant.name}));this.setData({markers: markers});},fail: (err) => {wx.showToast({title: '获取数据失败',icon: 'none'});console.error(err);}});},onMarkerTap: function(event) {const markerId = event.markerId;const marker = this.data.markers[markerId];wx.navigateTo({url: `/pages/restaurant/restaurant?name=${marker.title}`});}
});
  1. 详情页界面 (restaurant.wxml)
    在 pages/restaurant/restaurant.wxml 中展示餐厅详情:

xml

<view class="container"><text>餐厅名称: {{name}}</text>
</view>
  1. 详情页逻辑 (restaurant.js)
    在 pages/restaurant/restaurant.js 中实现显示餐厅名称:

javascript

Page({data: {name: ''},onLoad: function(options) {if (options.name) {this.setData({name: options.name});}}
});
  1. 设置样式 (index.wxss 和 restaurant.wxss)
    用简单的CSS样式美化页面:

index.wxss

.container {display: flex;flex-direction: column;align-items: center;justify-content: center;padding: 20px;
}button {margin-top
[好像出错了,请稍后再试。]

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词