使用开发工具的正确姿势
微信提供的开发工具的编辑功能不是一般的水,写代码肯定不能用它,否则就是浪费生命.不说别的,连自动保存都没有,第一次写时写了一个多小时,后面下班直接关掉,也不弹出提示说没保存.然后第二天过来,写的代码全没了!!! 顿时感到巨坑无比.这些工具开发人员吃干饭的么???
(后来的版本已经修复不能自动保存的问题了,当然编辑功能还是不好用.)
它的正确用法是作为运行和调试工具.
那么适合作为编辑工具的是: webStorm.基于IntelJ内核,开启Dracula主题,跟Android studio的使用习惯非常接近,so cool!各种方法提示,自动保存,快速查找...应有尽有.闭源的微信开发工具就不要用来写代码了,珍惜生命.
webStorm要识别wxml和wxss,还需要配置一下文件类型:(看下面别人截的图)
记住html和css里都要加上微信小程序对应的类型
综上,开发时,用webstorm来写代码,用微信开发工具来运行和调试,速度飕飕的!
网络请求的封装
微信提供了底层网络驱动以及成功和失败的回调.但对于一个项目中的实际使用而言,仍然还是显得繁琐,还有很多封装和简化的空间.
wx.request({ url: 'test.php',//请求的url data: {//请求的参数 x: '' , y: '' }, header: {//请求头 'Content-Type': 'application/json' }, method:"POST", success: function(res) {//成功的回调 console.log(res.data) } })网络框架二次封装的一般姿势
对于一个网络访问来说,请求一般是get和post,拼上各种参数以及请求头,然后拿到回来的响应,解析并得到最终需要的数据.
对于具体项目来说,请求时会有每个(或大多数)请求都要带的参数,都要带的请求头,返回的数据格式可能都是一致的,那么基于此,对微信的网络请求api进行二次封装:
在我目前的项目中,
请求:大多数请求是post,基本上每个请求都需要携带sessionId来与服务器验证登录状态,还有很多请求是基于分页的,需要带上pageSize和pageIndex.
再跟页面逻辑关联起来,请求可能是因为第一次进入页面,或者刷新,或者上拉加载更多.
大多数拿到的数据格式是标准json格式,如下
{ "code":1, "data":xxx,//可能是String,也可能是JsonObject,或JsonArray,也可能是null,或undefined "msg":yyy//可能为空 }通过请求的状态码code来判断这个请求是否真正成功.我们的项目中还有常见的是code=5:登录过期或未登录,code=2: 没有找到对应的内容 等等.
我们实际使用中需要的:如果是大多数情况的请求时,只需要指定:
url的尾部
该请求的非一般的参数
该请求由什么动作引起的(第一次进入,刷新,加载更多)
对于响应,我们只需要:
成功时:拿到data里面的数据
失败时,拿到失败的信息(细分一下,包括可以直接显示给用户的和不能让用户看到的),以及失败状态码
数据为空的回调:(常见于列表数据的加载)
我们期望的api是:
netUtil.buildRequest(page,urlTail,params,callback)//必须的参数和回调 .setXxx(xxx)//额外的设置,链式调用 .. .send();//最终发出请求的动作基于上面的分析,封装如下: 定义好携带构建请求的对象: //这两个错误码是项目接口文档统一定义好的 const code_unlogin = 5; const code_unfound = 2; function requestConfig(){ this.page; //页面对象 this.isNewApi = true; this.urlTail=''; this.params={ pageIndex:0, pageSize:getApp().globalData.defaultPageSize, session_id:getApp().globalData.session_id }; this.netMethod='POST'; this.callback={ onPre: function(){}, onEnd: function(){ }, onSuccess:function (data){}, onEmpty : function(){}, onError : function(msgCanShow,code,hiddenMsg){}, onUnlogin: function(){ this.onError("您还没有登录或登录已过期,请登录",5,'') }, onUnFound: function(){ this.onError("您要的内容没有找到",2,'') } }; this.setMethodGet = function(){ this.netMethod = 'GET'; return this; } this.setApiOld = function(){ this.isNewApi = false; return this; } this.send = function(){ request(this); } }
请求的封装 供我们调用的顶层api: //todo 拷贝这段代码去用--buildRequest里的callback /* onPre: function(){}, onEnd: function(){ hideLoadingDialog(page); }, onSuccess:function (data){}, onEmpty : function(){}, onError : function(msgCanShow,code,hiddenMsg){}, onUnlogin: function(){ this.onError("您还没有登录或登录已过期,请登录",5,'') }, onUnFound: function(){ this.onError("您要的内容没有找到",2,'') } * */ /** * 注意,此方法调用后还要调用.send()才是发送出去. * @param page * @param urlTail * @param params * @param callback 拷贝上方注释区的代码使用 * @returns {requestConfig} */ function buildRequest(page,urlTail,params,callback){ var config = new requestConfig(); config.page = page; config.urlTail = urlTail; if (getApp().globalData.session_id == null || getApp().globalData.session_id == ''){ params.session_id='' }else { params.session_id = getApp().globalData.session_id; } if (params.pageIndex == undefined || params.pageIndex <=0 || params.pageSize == 0){ params.pageSize=0 }else { if (params.pageSize == undefined){ params.pageSize = getApp().globalData.defaultPageSize; } } log(params) config.params = params; log(config.params) //config.callback = callback; if(isFunction(callback.onPre)){ config.callback.onPre=callback.onPre; } if(isFunction(callback.onEnd)){ config.callback.onEnd=callback.onEnd; } if(isFunction(callback.onEmpty)){ config.callback.onEmpty=callback.onEmpty; } if(isFunction(callback.onSuccess)){ config.callback.onSuccess=callback.onSuccess; } if(isFunction(callback.onError)){ config.callback.onError=callback.onError; } if(isFunction(callback.onUnlogin)){ config.callback.onUnlogin=callback.onUnlogin; } if(isFunction(callback.onUnFound)){ config.callback.onUnFound=callback.onUnFound; } return config; }