微信小程序常用简易小函数总结

最近一直在写微信小程序,而且由于是第二次写了,所以针对很多通用的情况封装了一些函数,建议你们放在app.js中,方便全局去调用。

提示类函数

微信有一种原生的API用于显示提示类结果的wx.showToast,而且其中的图片是可以自定义的,所以为了保证全部一致性,而且方便调用,所以我将其全部封装在了app.js中:

// 成功 showSuccess: function (message) { wx.showToast({ title: message, duration: 2000, image: "/images/Common/Success.png", }) }, // 错误 showError: function (message) { wx.showToast({ title: message, duration: 2000, image: "/images/Common/Error.png", }) }, // 警告 showWarn: function (message) { wx.showToast({ title: message, duration: 2000, image: "/images/Common/Warn.png", }) }

注意上面的duration参数,这个在下面的情况中是一个很重要的问题。

假设一般的操作是对一个页面的操作完成后接着显示处理结果,最后进行跳转。所以这里就存在一个问题,假设使用上面的弹出框进行显示,那么在弹出框显示之前就会进行跳转,这样处理结果就显示不全了,所以合理的做法是在弹出框结束后进行跳转。而如果将跳转单独封装在各个页面中,那么到时候进行时间长短的处理就很麻烦了,所以我将这个函数进行了封装:

// 第一个是路由,第二个则是判断是否是tabbar的路由,跳这两个路由是不一致的 completeOperating:function(to,isTabbar){ var time=setTimeout(function(){ if(isTabbar===true){ wx.switchTab({ url:to }) }else{ wx.navigateTo({ url: to }) } clearTimeout(time); },2000) }

还有一种情况就是我们开始将数据返回给后端,这个时候最好给用户一个加载中的提示,而这个提示可以使用wx.showLoadding来做:

// 提示用户数据保存中 startOperating:function(info){ wx.showLoading({ title:info, mask:true }) }

当后端返回结果后。则将加载框进行隐藏:

stopOperating:function(){ wx.hideLoading(); }

登录类问题

微信小程序不支持session,这个是前提,所以我们没办法在后端使用session来进行用户身份的区分。我的解决思路是这样的,在项目的入口文件app.js中的onLaunch函数中,即在用户开启小程序后调用wx.login()函数获取用户的唯一微信标志code,接着将该标志传回后端,调用微信的统一API,获取用户在该微信小程序中的唯一标识,注意,即使是同一个用户,在不同的微信小程序中标识也是不一样的。

获取该标识后,后端调用缓存将该标识缓存起来,时间也不用担心,由于写在app.js中,所以每次启动都会去询问后端,后端做相应的登录更新处理就可以了。

实际前端代码

// app.js APP({ onLaunch:function(){ this.login(); }, login:function(){ // 我喜欢把域名保存在globalData中,这样即使后期修改了域名,也不用到每个文件中去改 var that=this; wx.login({ success:function(res){ // 这里获取标识 var code=res.code; // 将该标识传递给后端 wx.request({ url:that.globalData.url+"/home/login/login?code="+code, success:function(res){ // 假设后端返回一个session_key作为改用户的唯一标识,所有请求都需要携带该参数 var session_key=res.data.session_key; // 调用全局缓存来保存该值 wx.setStorageSync('session_key', session_key); }, fail:function(error){ // 写这么一个函数,是帮助自己后期出现问题时可以进行修复 console.error("调用微信登录接口错误"); console.log(error); } }) } }) }, globalData:{ url:"http://yourdomain.com" } })

实际后端代码

class LoginController extends Controller{ // 你的小程序唯一标识 private $appid=""; private $secrect=""; public function login(){ // 获取前端传递过来的code $code=$_GET['code']; // 调用微信的统一API $baseUrl="https://api.weixin.qq.com/sns/jscode2session?appid={$this->appid}&secret={$this->secrect}&js_code={$code}&grant_type=authorization_code"; // 微信返回结果处理 $result=curl_get_contents($baseUrl); $user=json_decode($result,true); if($user['error_code']){ // 这里是调用错误的函数,如何解决看你自己的业务逻辑 exit(); } // 该用户在你小程序中的唯一标识 $openid=$user['openid']; // 判断是新用户还是老用户 $userInfo=M('User')->where(array('openid'=>$openid))->find(); if($userInfo){ // 老用户 $user_id=$userInfo['id']; $session_key=$this->getSessionKey($openid,$user_id); }else{ // 新用户则将其保存进数据库中 $user_id=M("User")->add(array('openid'=>$openid)); $session_key=$this->getSessionKey($openid,$user_id); } // 缓存起来,至于有效期最好长一点,以防止用户在使用过程中突然不能访问数据,我这里是使用tp框架的S()函数进行存储的 S($session_key,$user_id); // 以后只需要用户传递过来$session_key就可以根据缓存获取用户身份了 // 将结果发送给前端 $this->ajaxReturn(array( 'session_key'=>$session_key )); } // 生成用户的session_key private function getSessionKey($openid,$user_id){ $key="可以说是你的密钥吧"; return hash("md5",$key.$openid.$user_id); } }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/cbce5f61f50a55580defaa3afb8896eb.html