微信小程序 开发过程中遇到问题总结
第一次正式开发一个小程序,就从以下几个方面来谈一谈小程序的开发过程和心得吧,主要说说这次项目中用到的功能。
数据请求
这次的小程序,没有太多的附加功能,所以数据以及对数据的处理是这次的主体工作,小程序向用户提供API,供用户向自己的服务器请求数据,值得一提的是,开发小程序之前,需要先在微信公众平台申请appID,并且绑定域名,域名必须是https协议,然后在小程序的开发工具的配置信息中完善信息,请求的地址需要在前面绑定的域名下。这个项目中用到wx.request从服务器拉取数据。
?
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
wx.request({
url: that.data.couponData.requestUrl,
data: that.data.couponData.queryData,
header: {
content-type: application/json
},
success: function(res) {
var list = res.data.goodsList;
console.log(res.data);
for(var i in list) {
list[i].quanUsedNum = parseInt(list[i].quanTotalNum) - parseInt(list[i].quanRemainNum);
list[i].isImgRendered = false;
}
list[0].isImgRendered = list[1].isImgRendered = list[2].isImgRendered = list[3].isImgRendered = true;
that.setData({"couponData.totalPage":res.data.totalPage});
that.setData({"couponData.list":that.data.couponData.list.concat(list)});
that.setData({"couponData.loadmore":!that.data.couponData.loadmore});
that.setData({"couponData.queryData.pageNum":parseInt(that.data.couponData.queryData.pageNum) + 1});
if(that.data.couponData.queryData.pageNum > that.data.couponData.totalPage) {
that.setData({"couponData.isAction":false});
}
if(that.data.couponData.list.length < 1) {
that.setData({"couponData.nodata":true});
}
if(f) {
f();
}
}
});
数据缓存
这里使用数据缓存是因为需要做一个搜索功能,就涉及到页面之间的数据传递,放在地址中也是一种方法,借用一下localStorage也可以,使用wx.setStorage将数据存储到localStorage中,页面跳转之后,在从localStorage中读取就可以了,读取数据的时候分同步读取和异步读取。
剪切板的应用
借用小程序的API可以很方便的将任何信息复制到剪切板,然后就可以粘贴了。
?
1
2
3
4
5
6
wx.setClipboardData({
data: 【 + that.data.couponData.list[e.currentTarget.id].goodsTitle + 】复制这条信息,打开【手机淘宝】 + that.data.couponData.list[e.currentTarget.id].twoInOneKouling,
success: function(res) {
that.setData({"couponData.copyTip":true,"couponData.Kouling":that.data.couponData.list[e.currentTarget.id].twoInOneKouling})
}
});
模板
在这个项目中,页面基本很相似,但有细微差别,所以就使用了模板,新建一个template/template.wxml,name属性必须要设置。
模块化
对于公共的js可以写在一个专门的js文件中,然后使用module.exports暴露接口。
通用的js文件使用require引入。
?
1
2
3
var common = require(../../common/common.js);
...
common.f(); //调用
redirectTo & navigateTo
redirectTo是重定向至某页面,navigateTo是打开新的页面,值得说明的一点是,使用navigateTo打开的页面太多会导致小程序卡顿。
分享
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Page({
onShareAppMessage: function () {
return {
title: your title!,
path: /xxxx/xxxx/xxxx, //分享之后回到这个页面
success: function(res) {
f(); //成功回调;
},
fail: function(res) {
f(); //失败回调;
}
}
}
})
提高列表滑动的流畅性
简而言之就是页面滚动到哪里,列表中的图片就显示到哪里,实现方法如下。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//js文件
Page({
loadImg:function(e) {
//计算接下来加载哪几张
var index = Math.floor((e.detail.scrollTop - 8)/259.5);
var temp = this.data.couponData.list; //完整的列表
var min = Math.max(index * 2,0),max = Math.min(index * 2 + 8,temp.length);
for(var i = min; i < max; i ++) {
if(temp[i] && !temp[i].isImgRendered) {
temp[i].isImgRendered = true; //列表中的每一项有一个标记是否加载图片的的属性,默认false,随着页面滚动,一个个变成true。
}
}
this.setData({"couponData.list":temp});
temp = null;
},
})
//wxml文件中在scroll-view上绑定事件。
<scroll-view class="section" scroll-y="true" bindscroll=loadImg></scroll-view>
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:微信小程序中多个页面传参通信的学习与实践微信小程序 开发之全局配置微信小程序 图片上传实例详解微信小程序 wx:for的使用实例详解微信小程序 本地数据读取实例微信小程序 flex实现导航实例详解微信小程序访问node.js接口服务器搭建教程微信小程序 自动登陆PHP源码实例(源码-)
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~