微信小程序开发的示例分析

这篇文章主要为大家展示了“微信小程序开发的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“微信小程序开发的示例分析”这篇文章吧。

微信小程序 开发过程中遇到问题总结

微信小程序开发的示例分析

第一次正式开发一个小程序,就从以下几个方面来谈一谈小程序的开发过程和心得吧,主要说说这次项目中用到的功能。

数据请求

这次的小程序,没有太多的附加功能,所以数据以及对数据的处理是这次的主体工作,小程序向用户提供API,供用户向自己的服务器请求数据,值得一提的是,开发小程序之前,需要先在微信公众平台申请appID,并且绑定域名,域名必须是https协议,然后在小程序的开发工具的配置信息中完善信息,请求的地址需要在前面绑定的域名下。这个项目中用到wx.request从服务器拉取数据。

wx.request({
url:that.data.couponData.requestUrl,
data:that.data.couponData.queryData,
header:{
'content-type':'application/json'
},
success:function(res){
varlist=res.data.goodsList;
console.log(res.data);
for(variinlist){
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可以很方便的将任何信息复制到剪切板,然后就可以粘贴了。

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属性必须要设置。

<templatename='navsearch'>
<viewclass='nav-search'>
<viewclass='nav-search__containerspace-between'>
<viewclass='nav-search__search'wx:if='{{isSearch}}'></view>
<inputclass='nav-search__input'placeholder='请输入关键词找券'name='queryStr'value="{{queryStr}}"bindfocus='toggleSearch'bindconfirm='doQuery'bindinput="syncQuery"/>
<viewclass='nav-search__delete'wx:if='{{!isSearch}}'bindtap='deleteAll'></view>
<viewclass='nav-search__btncenter'wx:if='{{!isSearch}}'bindtap='doQuery'>搜索</view>
</view>

<viewclass='nav-filter'bindtap='toggleFilter'></view>
</view>
</template>

<!--在其他文件中使用模板-->
<importsrc="/template/template.wxml"/>
<templateis='navsearch'data="{{...couponData}}"></template>

模块化

对于公共的js可以写在一个专门的js文件中,然后使用module.exports暴露接口。通用的js文件使用require引入。

varcommon=require('../../common/common.js');
...
common.f();//调用

redirectTo & navigateTo

redirectTo是重定向至某页面,navigateTo是打开新的页面,值得说明的一点是,使用navigateTo打开的页面太多会导致小程序卡顿。

分享

Page({
onShareAppMessage:function(){
return{
title:'yourtitle!',
path:'/xxxx/xxxx/xxxx',//分享之后回到这个页面
success:function(res){
f();//成功回调;
},
fail:function(res){
f();//失败回调;

}
}
}
})

提高列表滑动的流畅性

简而言之就是页面滚动到哪里,列表中的图片就显示到哪里,实现方法如下。

//js文件
Page({
loadImg:function(e){
//计算接下来加载哪几张
varindex=Math.floor((e.detail.scrollTop-8)/259.5);
vartemp=this.data.couponData.list;//完整的列表
varmin=Math.max(index*2,0),max=Math.min(index*2+8,temp.length);
for(vari=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-viewclass="section"scroll-y="true"bindscroll='loadImg'></scroll-view>

以上是“微信小程序开发的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注恰卡编程网行业资讯频道!

发布于 2021-06-13 23:19:13
收藏
分享
海报
0 条评论
179
上一篇:IntelliJ IDEA中怎么新建一个Java class项目 下一篇:springBoot项目启动类启动无法访问如何解决
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码