小程序 是否授权、支付、开屏页跳转到tabbar、跳转携带参数、表单值验证保存

wx.login()

微信登录的原理
调用 login()成功之后获取一个用户登录凭证 code,再发送 request 请求给第三方服务器解析获得会话密钥和 openid

获取用户的手机号码

要先调用login()成功之后返回一个code,需用 <button> 组件的点击来触发,个人开发者不能用,open-type 设置为 getPhoneNumber ,当用户点击并同意之后,可以通过 bindgetphonenumber 事件回调获取到微信服务器返回的加密数据(e.detail.encryptedData,iv), 然后在第三方服务端结合 session_key 以及 openid 进行解密获取手机号。(res.phone,countryCode,appid)

授权

部分接口需要权限,接口按使用范围分成多个 scope,9 个(用户信息,地理位置,通讯地址,发票抬头,获取发票,微信运动步数,录音功能,保存到相册,摄像头),
wx.authorize()在调用需授权 API 之前,提前向用户发起授权请求wx.authorize({scope: "scope.userInfo"}),不会弹出授权窗口,请使用 <button open-type="getUserInfo"/>
wx.getSetting()获取用户的当前设置
wx.openSetting()打开设置界面,引导用户开启授权

获取用户信息(昵称,头像,语言,城市,身份,国家)

获取用户信息之前需要用户授权

button 组件去触发 getUserInof 接口,bindgetuserinfo绑定

button的open-type 的合法值:
contact、share\getPhoneNumber\getUserInfo\launchApp\openSetting\feedback

3微信支付的原理
wx.requestPayment()
前台调用后台接口→后台调用微信统一下单接口,后台返回调用微信统一下单后返回的内容给前台→前台根据后台返回的内容调用微信浏览器内置JS弹出支付→支付后有两种处理 ①前台支付成功后的页面 ②微信回调url(一般处理业务逻辑)

购物车的业务逻辑

选商品 下单 生成订单号 提交服务器

// 可以通过 wx.getSetting 先查询一下用户是否授权了 "scope.record" 这个 scope
wx.getSetting({
  success(res) {
    if (!res.authSetting['scope.record']) {
      wx.authorize({
        scope: 'scope.record',
        success () {
          // 用户已经同意小程序使用录音功能,后续调用 wx.startRecord 接口不会弹窗询问
          wx.startRecord()
        }
      })
    }
  }
})


/* 支付   */
 
function paynow(param, callback) {
 
wx.requestPayment({
 
timeStamp: param.timeStamp,
 
nonceStr: param.nonceStr,
 
package: param.package,
 
signType: param.signType,
 
paySign: param.paySign,
 
success:function (res) {
 
// success      
 
callback();
 
 
 
wx.navigateBack({
 
delta: 1,// 回退前 delta(默认为1) 页面
 
success:function (res1) {
 
wx.showToast({
 
title:'支付成功',
 
icon:'success',
 
duration: 2000
 
});
 
 
 
},
 
fail:function () {
 
// fail
 
 
 
},
 
complete:function () {
 
 
 
}
 
})
 
},
 
fail:function (res) {
 
// fail
 
},
 
complete:function () {
 
// complete
 
}
 
})
 
}

小程序开屏页是个图片 3秒后跳转到tabar页面
wxml

<view class="start">
        <swiper-item>
            <image src="./../../img/start.jpg" class="slide-image" bindload="bindload" />
        </swiper-item>
</view>

js页面 开屏页跳转到tabbar不能用 wx.navigateTo 得用 wx.switchTab

 bindload(e) {
        setTimeout(this.goIndex, 3000)
    },
    goIndex() {
        wx.switchTab({
            url: '/pages/index/index'
            });
    },

json页面
设置title和顶部导航背景色

{
    "navigationBarBackgroundColor": "#2dc8b7",
    "navigationBarTitleText": "欢迎您的到来",
    "disableScroll": true
}

跳转携带参数
wxml页面

 <view class="item" bindtap="itemclick" data-specId="{{item.specId}}">

js页面

  //跳转到goodsdetail
  itemclick: function (e) {
    var specId = e.currentTarget.dataset.specid;
    wx.navigateTo({
      url: '../goodsDetail/goodsDetail?specId=' + specId,

    })
  },

表单验证保存


 //保存
  addAddress:function(){
    var that = this;
    if(that.data.name.length == 0){
        wx.showToast({
            title: '收货人不能为空',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.phoneNum.length == 0){
        wx.showToast({
            title: '手机号不能为空',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.zipCode.length == 0){
        wx.showToast({
            title: '邮编不能为空',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.pId.length == 0){
        wx.showToast({
            title: '请选所在省份',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.cId.length == 0){
        wx.showToast({
            title: '请选择所在市',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.dId.length == 0){
        wx.showToast({
            title: '请选择所在区县',
            icon: 'loading',
            mask: true
        })
    }else if(that.data.detailAddress.length == 0){
        wx.showToast({
            title: '详细地址不能为空为空',
            icon: 'loading',
            mask: true
        })
    }else{
        request.req(uri_save_address, {
            trueName: that.data.name,
            mobPhone: that.data.phoneNum,
            zipCode: that.data.zipCode,
            provinceId: that.data.pId,
            cityId: that.data.cId,
            areaId: that.data.dId,
            areaInfo:that.data.pName+','+ that.data.cName+','+ that.data.dName,
            address: that.data.detailAddress,
        }, (err, res) => {
            var result = res.data;
            if (result.result == 1) { //地址保存成功
            wx.navigateBack({
                delta: 1, // 回退前 delta(默认为1) 页面
                success: function(res){
                // success
                },
                fail: function() {
                // fail
                },
                complete: function() {
                // complete
                }
            })
            } else {
                wx.showToast({
                    title: '保存失败',
                    icon: 'loading',
                    duration: 1500
                })
            }
        })
    }
  },
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容