微信小程序地图案例

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

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

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

  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

java 复制代码
{
  "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

html 复制代码
<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

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

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

javascript

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

index.wxss

css 复制代码
.container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

button {
  margin-top
[好像出错了,请稍后再试。]
相关推荐
暮雨哀尘20 小时前
微信小程序开发:开发实践
开发语言·算法·微信小程序·小程序·notepad++·性能·技术选型
arbboter2 天前
【AI插件开发】Notepad++ AI插件开发实践:从Dock窗口集成到功能菜单实现
人工智能·notepad++·动态菜单·notepad++插件开发·dock窗口集成·ai代码辅助工具·ai对话窗口
web_Hsir3 天前
uniapp 微信小程序项目中 地图 map组件 滑动面板
微信小程序·uni-app·notepad++
森叶5 天前
Git Bash 设置Notepad++作为默认编辑器
git·编辑器·notepad++
暮雨哀尘5 天前
微信小程序开发:微信小程序组件应用研究
算法·微信·微信小程序·小程序·notepad++·微信公众平台·组件
BabyFish136 天前
notepad++ 正则表达式
正则表达式·notepad++
arbboter6 天前
【Ai插件开发】Notepad++ AI插件开发进阶:集成Ai模型问答功能与流式交互实现
人工智能·notepad++·notepad++插件开发·ai模型集成·流式响应处理·scintilla控件交互·winhttp封装应用
arbboter7 天前
【AI工具开发】Notepad++插件开发实践:从基础交互到ScintillaCall集成
人工智能·编辑器·notepad++·插件开发·scintilla·scintillacall·scintilla类封装
summer__77777 天前
notepad++代码查看器分享
notepad++
strggle_bin8 天前
Notepad++ 替换 换行符 为 逗号
notepad++