微信小程序-从零开始制作一个跑步微信小程序

2019-10-29 04:20 来源:未知

32450新蒲京网站,前言

本文作者: 伯乐在线 - 王小树 。未经作者许可,禁止转载!
欢迎加入伯乐在线 专栏作者。

我已经把全部代码放在github上-weChatApp-Run,可以下载来看看或者先star收藏,我以后还会进行一些优化更新。现在只是一个学习Demo,大家沟通学习,实际应用还需更多优化。

一、准备工作

正文

1、注册一个小程序账号,得用一个没注册过公众号的邮箱注册。
2、注册过程中需要很多认证,有很多认证,比较繁琐,如果暂时只是开发测试,不进行提审、发布的话,只要完成营业执照号填写就可以了,不需要完成微信认证。
3、注册完账号,登录,在主页面左边列表中点击设置,然后再设置页面中选开发设置就可以看到AppID,用于登录开发工具。

一、准备工作

32450新蒲京网站 1

1、注册一个小程序账号,得用一个没注册过公众号的邮箱注册。

主页面

2、注册过程中需要很多认证,有很多认证,比较繁琐,如果暂时只是开发测试,不进行提审、发布的话,只要完成营业执照号填写就可以了,不需要完成微信认证。

32450新蒲京网站 2

3、注册完账号,登录,在主页面左边列表中点击设置,然后再设置页面中选开发设置就可以看到AppID,用于登录开发工具。

设置页面

主页面

二、开发工具

可以到官网下载开发工具下载

32450新蒲京网站 3

开发工具

32450新蒲京网站 4

开发工具编辑页面

设置页面

三、开始项目

打开开发者工具,选择小程序选项,到达添加项目页面

32450新蒲京网站 5

添加项目

这个时候在前面设置页面的AppId就用到了。

如果项目目录中的文件是个空文件夹,会提示是否创建quick start 项目。
选择“是”,开发者工具会帮助我们在开发目录里生成一个简单的 demo。
这个Demo拥有一个完整的小程序的大概框架。

二、开发工具

1、框架

先看下一目录:

32450新蒲京网站 6

文件目录.png

app.js: 小程序逻辑,生命周期,,全局变量
app.json: 小程序公共设置,导航栏颜色等,不可以注释
app.wxss :小程序公共样式,类CSS 。

可以到官网下载开发工具下载

小程序页面构成:

32450新蒲京网站 7

页面构成

每一个小程序页面是由同路径下同名的四个不同后缀文件的组成,如:index.js、index.wxml、index.wxss、index.json。

32450新蒲京网站 8

葛文佳介绍

微信小程序中的每一个页面的【路径+页面名】都需要写在 app.json 的 pages 中,且 pages 中的第一个页面是小程序的首页。

32450新蒲京网站 9

路径

这四个文件按照功能可以分成三个部分:

配置:json 文件
逻辑层:js文件
视图层:wxss.wxml文件

在 iOS 上,小程序的 javascript 代码是运行在 JavaScriptCore 中
在 Android 上,小程序的 javascript 代码是通过 X5 内核来解析
在 开发工具上, 小程序的 javascript 代码是运行在 nwjs(chrome内核) 中。所以开发工具上的效果跟实际效果有所出入。

开发工具

2、组件

微信提供了许多组件,主要分为八种:

视图容器、
基础内容、
表单组件、
操作反馈、
导航、
媒体组件、
地图、
画布

包含view、scroll-view、button、form等普通常用的组件,也提供了地图map、画布canvas

组件主要属于视图层,通过wxml来进行结构布局,类似于html。通过wxss修改样式,类似于css。
组件使用语法实例:

这是一个普通视图样式修改过的视图

1
2
 
这是一个普通视图样式修改过的视图

更多的组件以及相关使用方法可以到官方文档-组件查看

开发工具编辑页面

3、API

网络
媒体
数据
位置
设备
界面
开发接口

其中网络请求的使用必须先到公众平台登录小程序账号,在设置页面那里,设置允许访问的域名,网络请求包含了普通的http请求、支持上传、下载、socket。基本上满足了我们开发中所需要的网络需求。

这些API属于逻辑层,写在js文件中,
使用实例:

wx.getLocation({ type: 'wgs84', success: function(res) { var latitude = res.latitude var longitude = res.longitude var speed = res.speed var accuracy = res.accuracy }})

1
2
3
4
5
6
7
8
wx.getLocation({
   type: 'wgs84',
   success: function(res) {
       var latitude = res.latitude
       var longitude = res.longitude
       var speed = res.speed
       var accuracy = res.accuracy
}})

可以到官方文档-API查看其它API的使用方法。

三、开始项目

4、编译运行

1、模拟器
可以在模拟器上看效果,上面降到了运行底层不同,效果跟在手机上运行有些差异

32450新蒲京网站 10

模拟器.png

2、真机
在左边的选项栏中,选择项目,然后点预览会生产一个二维码,用管理员微信号扫一扫就可以在真机上看实际效果

32450新蒲京网站 11

Paste_Image.png

打开开发者工具,选择小程序选项,到达添加项目页面

实践–跑步小程序。

添加项目

真机运行截图(运行于iPhone7,微信版本:6.3.30):

32450新蒲京网站 12

home.jpeg

32450新蒲京网站 13

run.jpeg

32450新蒲京网站 14

slideback.jpeg

32450新蒲京网站 15

slide.jpeg

这个时候在前面设置页面的AppId就用到了。

功能:

能够计算里程、时间、实时获取跑步路径(有些粗糙)

如果项目目录中的文件是个空文件夹,会提示是否创建quick start 项目。

思路:

主要使用了微信小程序的获取位置APIwx.getLocation()和地图组件map
首先实现一个计时器进行 计时,通过wx.getLocation()获取坐标,把获取到的坐标存在一个数组中,通过坐标每隔一段时间获取里程,进行累加得到总里程,同时也通过坐标点进行连线
存在的问题:
1、因为目前找不到在地图上画连线的方法,所以采用了在地图上贴小红点图的方法显示大概跑步路径,路径比较粗糙。
2、虽然采用了API里面的火星坐标gcj02类型,但是获取的坐标跟国际坐标差不多,依然存在着偏差。

选择“是”,开发者工具会帮助我们在开发目录里生成一个简单的 demo。

核心代码:

我把全部代码放在github上-weChatApp-Run,可以下载来看看或者先star收藏,我以后还会进行一些优化更新。现在只是一个学习Demo,大家沟通学习,实际应用还需更多优化。

wxml文件布局代码:

XHTML

<view class="head" style="flex-direction:row;"> <image class="icon" src="/resources/joyrun.png" mode="aspectFill"/> <button bindtap="openLocation">打开位置</button> <button bindtap="starRun">开始跑步</button> <button bindtap="stopRun">暂停跑步</button> <text>n里程数:{{meters}}km</text> <text>nn时间:{{time}}</text> </view> <view class="mainView"> <map class="mapView" style="width: 100%; height: 375px;" latitude="{{latitude}}" longitude="{{longitude}}" markers="{{markers}}" covers="{{covers}}" > </map> </view>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<view class="head" style="flex-direction:row;">
    <image class="icon" src="/resources/joyrun.png" mode="aspectFill"/>
    <button bindtap="openLocation">打开位置</button>
    <button bindtap="starRun">开始跑步</button>
    <button bindtap="stopRun">暂停跑步</button>
    <text>n里程数:{{meters}}km</text>
    <text>nn时间:{{time}}</text>
</view>
 
<view class="mainView">
   <map
        class="mapView"
        style="width: 100%; height: 375px;"
        latitude="{{latitude}}"
        longitude="{{longitude}}"
        markers="{{markers}}"
        covers="{{covers}}"
        >
    </map>
 
</view>

js文件逻辑代码:

JavaScript

var countTooGetLocation = 0; var total_micro_second = 0; var starRun = 0; var totalSecond = 0; var oriMeters = 0.0; /* 毫秒级倒计时 */ function count_down(that) { if (starRun == 0) { return; } if (countTooGetLocation >= 100) { var time = date_format(total_micro_second); that.updateTime(time); } if (countTooGetLocation >= 5000) { //1000为1s that.getLocation(); countTooGetLocation = 0; } setTimeout setTimeout(function(){ countTooGetLocation += 10; total_micro_second += 10; count_down(that); } ,10 ) } // 时间格式化输出,如03:25:19 86。每10ms都会调用一次 function date_format(micro_second) { // 秒数 var second = Math.floor(micro_second / 1000); // 小时位 var hr = Math.floor(second / 3600); // 分钟位 var min = fill_zero_prefix(Math.floor((second - hr * 3600) / 60)); // 秒位 var sec = fill_zero_prefix((second - hr * 3600 - min * 60));// equal to => var sec = second % 60; return hr + ":" + min + ":" + sec + " "; } function getDistance(lat1, lng1, lat2, lng2) { var dis = 0; var radLat1 = toRadians(lat1); var radLat2 = toRadians(lat2); var deltaLat = radLat1

  • radLat2; var deltaLng = toRadians(lng1) - toRadians(lng2); var dis = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(deltaLat / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(deltaLng / 2), 2))); return dis * 6378137; function toRadians(d) { return d * Math.PI / 180;} } function fill_zero_prefix(num) { return num < 10 ? "0" + num : num } //**************************************************************************************** //**************************************************************************************** Page({ data: { clock: '', isLocation:false, latitude: 0, longitude: 0, markers: [], covers: [], meters: 0.00, time: "0:00:00" }, //**************************** onLoad:function(options){ // 页面初始化 options为页面跳转所带来的参数 this.getLocation() console.log("onLoad") count_down(this); }, //**************************** openLocation:function (){ wx.getLocation({ type: 'gcj02', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标 success: function(res){ wx.openLocation({ latitude: res.latitude, // 纬度,范围为-90~90,负数表示南纬 longitude: res.longitude, // 经度,范围为-180~180,负数表示西经 scale: 28, // 缩放比例 }) }, }) }, //**************************** starRun :function () { if (starRun == 1) { return; } starRun = 1; count_down(this); this.getLocation(); }, //**************************** stopRun:function () { starRun = 0; count_down(this); }, //**************************** updateTime:function (time) { var data = this.data; data.time = time; this.data = data; this.setData ({ time : time, }) }, //**************************** getLocation:function () { var that = this wx.getLocation({ type: 'gcj02', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标 success: function(res){ console.log("res----------") console.log(res) //make datas var newCover = { latitude: res.latitude, longitude: res.longitude, iconPath: '/resources/redPoint.png', }; var oriCovers = that.data.covers; console.log("oriMeters----------") console.log(oriMeters); var len = oriCovers.length; var lastCover; if (len == 0) { oriCovers.push(newCover); } len = oriCovers.length; var lastCover = oriCovers[len-1]; console.log("oriCovers----------") console.log(oriCovers,len); var newMeters = getDistance(lastCover.latitude,lastCover.longitude,res.latitude,res.longitude)/1000; if (newMeters < 0.0015){ newMeters = 0.0; } oriMeters = oriMeters + newMeters; console.log("newMeters----------") console.log(newMeters); var meters = new Number(oriMeters); var showMeters = meters.toFixed(2); oriCovers.push(newCover); that.setData({ latitude: res.latitude, longitude: res.longitude, markers: [], covers: oriCovers, meters:showMeters, }); }, }) } })
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
var countTooGetLocation = 0;
var total_micro_second = 0;
var starRun = 0;
var totalSecond  = 0;
var oriMeters = 0.0;
/* 毫秒级倒计时 */
function count_down(that) {
 
    if (starRun == 0) {
      return;
    }
 
    if (countTooGetLocation >= 100) {
      var time = date_format(total_micro_second);
      that.updateTime(time);
    }
 
      if (countTooGetLocation >= 5000) { //1000为1s
        that.getLocation();
        countTooGetLocation = 0;
      }  
 
 
setTimeout
      setTimeout(function(){
        countTooGetLocation += 10;
    total_micro_second += 10;
        count_down(that);
    }
    ,10
    )
}
 
 
// 时间格式化输出,如03:25:19 86。每10ms都会调用一次
function date_format(micro_second) {
      // 秒数
      var second = Math.floor(micro_second / 1000);
      // 小时位
      var hr = Math.floor(second / 3600);
      // 分钟位
      var min = fill_zero_prefix(Math.floor((second - hr * 3600) / 60));
      // 秒位
    var sec = fill_zero_prefix((second - hr * 3600 - min * 60));// equal to => var sec = second % 60;
 
 
    return hr + ":" + min + ":" + sec + " ";
}
 
 
function getDistance(lat1, lng1, lat2, lng2) {
    var dis = 0;
    var radLat1 = toRadians(lat1);
    var radLat2 = toRadians(lat2);
    var deltaLat = radLat1 - radLat2;
    var deltaLng = toRadians(lng1) - toRadians(lng2);
    var dis = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(deltaLat / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(deltaLng / 2), 2)));
    return dis * 6378137;
 
    function toRadians(d) {  return d * Math.PI / 180;}
}
 
function fill_zero_prefix(num) {
    return num < 10 ? "0" + num : num
}
 
//****************************************************************************************
//****************************************************************************************
 
Page({
  data: {
    clock: '',
    isLocation:false,
    latitude: 0,
    longitude: 0,
    markers: [],
    covers: [],
    meters: 0.00,
    time: "0:00:00"
  },
 
//****************************
  onLoad:function(options){
    // 页面初始化 options为页面跳转所带来的参数
    this.getLocation()
    console.log("onLoad")
    count_down(this);
  },
  //****************************
  openLocation:function (){
    wx.getLocation({
      type: 'gcj02', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标
      success: function(res){
          wx.openLocation({
            latitude: res.latitude, // 纬度,范围为-90~90,负数表示南纬
            longitude: res.longitude, // 经度,范围为-180~180,负数表示西经
            scale: 28, // 缩放比例
          })
      },
    })
  },
 
 
//****************************
  starRun :function () {
    if (starRun == 1) {
      return;
    }
    starRun = 1;
    count_down(this);
    this.getLocation();
  },
 
 
//****************************
  stopRun:function () {
    starRun = 0;
    count_down(this);
  },
 
 
//****************************
  updateTime:function (time) {
 
    var data = this.data;
    data.time = time;
    this.data = data;
    this.setData ({
      time : time,
    })
 
  },
 
 
//****************************
  getLocation:function () {
    var that = this
    wx.getLocation({
 
      type: 'gcj02', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标
      success: function(res){
        console.log("res----------")
        console.log(res)
 
        //make datas
        var newCover = {
            latitude: res.latitude,
            longitude: res.longitude,
            iconPath: '/resources/redPoint.png',
          };
        var oriCovers = that.data.covers;
 
        console.log("oriMeters----------")
        console.log(oriMeters);
        var len = oriCovers.length;
        var lastCover;
        if (len == 0) {
          oriCovers.push(newCover);
        }
        len = oriCovers.length;
        var lastCover = oriCovers[len-1];
 
        console.log("oriCovers----------")
        console.log(oriCovers,len);
 
        var newMeters = getDistance(lastCover.latitude,lastCover.longitude,res.latitude,res.longitude)/1000;
 
        if (newMeters < 0.0015){
            newMeters = 0.0;
        }
 
        oriMeters = oriMeters + newMeters;
        console.log("newMeters----------")
        console.log(newMeters);
 
 
        var meters = new Number(oriMeters);
        var showMeters = meters.toFixed(2);
 
        oriCovers.push(newCover);
 
        that.setData({
          latitude: res.latitude,
          longitude: res.longitude,
          markers: [],
          covers: oriCovers,
          meters:showMeters,
        });
      },
    })
  }
 
})

这个Demo拥有一个完整的小程序的大概框架。

五、后语

本文是一个快速上手开发的介绍,细节介绍可以查看官方文档
我的相关全部代码放在github上-weChatApp-Run

打赏支持我写出更多好文章,谢谢!

打赏作者

1、框架

打赏支持我写出更多好文章,谢谢!

任选一种支付方式

32450新蒲京网站 16 32450新蒲京网站 17

2 赞 7 收藏 1 评论

先看下一目录:

关于作者:王小树

32450新蒲京网站 18

王小树,alanwangmodify 个人主页 · 我的文章 · 5 ·     

文件目录.png

app.js: 小程序逻辑,生命周期,,全局变量

app.json: 小程序公共设置,导航栏颜色等,不可以注释

app.wxss :小程序公共样式,类CSS 。

小程序页面构成:

页面构成

每一个小程序页面是由同路径下同名的四个不同后缀文件的组成,如:index.js、index.wxml、index.wxss、index.json。

葛文佳介绍

微信小程序中的每一个页面的【路径+页面名】都需要写在 app.json 的 pages 中,且 pages 中的第一个页面是小程序的首页。

路径

这四个文件按照功能可以分成三个部分:

配置:json 文件

逻辑层:js文件

视图层:wxss.wxml文件

在 iOS 上,小程序的 javascript 代码是运行在 JavaScriptCore 中

在 Android 上,小程序的 javascript 代码是通过 X5 内核来解析

在 开发工具上, 小程序的 javascript 代码是运行在 nwjs(chrome内核) 中。所以开发工具上的效果跟实际效果有所出入。

2、组件

微信提供了许多组件,主要分为八种:

视图容器、

基础内容、

表单组件、

操作反馈、

导航、

媒体组件、

地图、

画布

包含view、scroll-view、button、form等普通常用的组件,也提供了地图map、画布canvas。

组件主要属于视图层,通过wxml来进行结构布局,类似于html。通过wxss修改样式,类似于css。

组件使用语法实例:

这是一个普通视图样式修改过的视图

更多的组件以及相关使用方法可以到官方文档-组件查看

3、API

网络

媒体

数据

位置

设备

界面

开发接口

其中网络请求的使用必须先到公众平台登录小程序账号,在设置页面那里,设置允许访问的域名,网络请求包含了普通的http请求、支持上传、下载、socket。基本上满足了我们开发中所需要的网络需求。

这些API属于逻辑层,写在js文件中,

使用实例:

wx.getLocation({type:'wgs84',  success:function(res) {      var latitude = res.latitude        var longitude = res.longitude        var speed = res.speed        var accuracy = res.accuracy }})

可以到官方文档-API查看其它API的使用方法。

4、编译运行

1、模拟器

可以在模拟器上看效果,上面讲到了运行底层不同,效果跟在手机上运行有些差异

模拟器.png

2、真机

在左边的选项栏中,选择项目,然后点预览会生产一个二维码,用管理员微信号扫一扫就可以在真机上看实际效果

Paste_Image.png

实践--跑步小程序。

真机运行截图(运行于iPhone7,微信版本:6.3.30):

home.jpeg

run.jpeg

slideback.jpeg

slide.jpeg

功能:

能够计算里程、时间、实时获取跑步路径(有些粗糙)

思路:

主要使用了微信小程序的获取位置APIwx.getLocation()和地图组件map。

首先实现一个计时器进行 计时,通过wx.getLocation()获取坐标,把获取到的坐标存在一个数组中,通过坐标每隔一段时间获取里程,进行累加得到总里程,同时也通过坐标点进行连线

存在的问题:

1、因为目前找不到在地图上画连线的方法,所以采用了在地图上贴小红点图的方法显示大概跑步路径,路径比较粗糙。

2、虽然采用了API里面的火星坐标gcj02类型,但是获取的坐标跟国际坐标差不多,依然存在着偏差。

核心代码:

我把全部代码放在github上-weChatApp-Run,可以下载来看看或者先star收藏,我以后还会进行一些优化更新。现在只是一个学习Demo,大家沟通学习,实际应用还需更多优化。

wxml文件布局代码:

打开位置开始跑步暂停跑步\n里程数:{{meters}}km\n\n时间:{{time}}

js文件逻辑代码:

varcountTooGetLocation =0;vartotal_micro_second =0;varstarRun =0;vartotalSecond  =0;varoriMeters =0.0;/* 毫秒级倒计时 */functioncount_down(that){if(starRun ==0) {return;    }if(countTooGetLocation >=100) {vartime = date_format(total_micro_second);      that.updateTime(time);    }if(countTooGetLocation >=5000) {//1000为1sthat.getLocation();        countTooGetLocation =0;    }        setTimeout    setTimeout(function(){        countTooGetLocation +=10;    total_micro_second +=10;        count_down(that);    }    ,10)}// 时间格式化输出,如03:25:19 86。每10ms都会调用一次functiondate_format(micro_second){// 秒数varsecond =Math.floor(micro_second /1000);// 小时位varhr =Math.floor(second /3600);// 分钟位varmin = fill_zero_prefix(Math.floor((second - hr *3600) /60));// 秒位varsec = fill_zero_prefix((second - hr *3600- min *60));// equal to => var sec = second % 60;returnhr +":"+ min +":"+ sec +" ";}functiongetDistance(lat1, lng1, lat2, lng2){vardis =0;varradLat1 = toRadians(lat1);varradLat2 = toRadians(lat2);vardeltaLat = radLat1 - radLat2;vardeltaLng = toRadians(lng1) - toRadians(lng2);vardis =2*Math.asin(Math.sqrt(Math.pow(Math.sin(deltaLat /2),2) +Math.cos(radLat1) *Math.cos(radLat2) *Math.pow(Math.sin(deltaLng /2),2)));returndis *6378137;functiontoRadians(d){returnd *Math.PI /180;}}functionfill_zero_prefix(num){returnnum <10?"0"+ num : num}//****************************************************************************************//****************************************************************************************Page({data: {clock:'',isLocation:false,latitude:0,longitude:0,markers: [],covers: [],meters:0.00,time:"0:00:00"},//****************************onLoad:function(options){// 页面初始化 options为页面跳转所带来的参数this.getLocation()console.log("onLoad")    count_down(this);  },//****************************openLocation:function(){    wx.getLocation({type:'gcj02',// 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标success:function(res){          wx.openLocation({latitude: res.latitude,// 纬度,范围为-90~90,负数表示南纬longitude: res.longitude,// 经度,范围为-180~180,负数表示西经scale:28,// 缩放比例})      },    })  },//****************************starRun :function(){if(starRun ==1) {return;    }    starRun =1;    count_down(this);this.getLocation();  },//****************************stopRun:function(){    starRun =0;    count_down(this);  },//****************************updateTime:function(time){vardata =this.data;    data.time = time;this.data = data;this.setData ({time: time,    })  },//****************************getLocation:function(){varthat =thiswx.getLocation({type:'gcj02',// 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标success:function(res){console.log("res----------")console.log(res)//make datas varnewCover = {latitude: res.latitude,longitude: res.longitude,iconPath:'/resources/redPoint.png',          };varoriCovers = that.data.covers;console.log("oriMeters----------")console.log(oriMeters);varlen = oriCovers.length;varlastCover;if(len ==0) {          oriCovers.push(newCover);        }        len = oriCovers.length;varlastCover =

oriCovers[len-1];console.log("oriCovers----------")console.log(oriCovers,len);varnewMeters

getDistance(lastCover.latitude,lastCover.longitude,res.latitude,res.longitude)/1000;if(newMeters <0.0015){            newMeters =0.0;        }        oriMeters = oriMeters + newMeters;console.log("newMeters----------")console.log(newMeters);varmeters =newNumber(oriMeters);varshowMeters = meters.toFixed(2);        oriCovers.push(newCover);                that.setData({latitude: res.latitude,longitude: res.longitude,markers: [],covers: oriCovers,meters:showMeters,        });      },    })  }  })

五、后语

本文是一个快速上手开发的介绍,细节介绍可以查看官方文档

我的相关全部代码放在github上-weChatApp-Run

作者:alanwangmodify

链接:

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

TAG标签:
版权声明:本文由32450新蒲京网站发布于葡萄游戏厅_体育游戏,转载请注明出处:微信小程序-从零开始制作一个跑步微信小程序