但是公司的很多项目都是用网页写的,也没有类

支出功效

webview里面能够通过jssdk来完结部分小程序效用,但不能够直接调用小程序的支付功用,那时候我们就供给转移一下政策了:

  1. 在网页里引入微信jssdk
  2. 在网页必要倡导支付的地点,调用跳转页面包车型客车接口,调整小程序跳转到小程序的开支页面(那些要在小程序里单独写的),跳转的时候,要求把订单的有的音信都凑合到链接里,订单新闻由后台重回,必要通过微信支付类其他会合下单接口,具体参看支付文书档案。
  3. 跳转到小程序支付页面后,由小程序页面发起支付,支付达成后跳转回webview页面,通过在此以前安装的动态src,调整webview跳转到特定的页面。

JavaScript

// 网页引进jssdk // 网页发起支付 wx.miniProgram.navigateTo({ // payData由后台再次回到,重尽管内需统一下单平台的prepay_id url: '../pay/index?data=' + encodeU君越IComponent(JSON.stringify(payData)) }) // 微信支付页面 onLoad: function (option) { let page = this try { let data = JSON.parse(option.data) if (!data || !data.prepay_id) { console.error('支付参数错误,请稍后重试', data) } wx.requestPayment({ timeStamp: '' + data.timestamp, nonceStr: data.nonceStr, package: 'prepay_id=' + data.prepay_id, paySign: data.paySign, signType: data.signType, success: function (res) { getApp().globalData.urlToken = `paySuccess.html` // 支付成功 getApp().globalData.urlData = 'data=paySuccessData' wx.navigateTo({ url: '/page/home/index', }) }, fail: function (res) { getApp().globalData.urlToken = `payError.html` // 支付失利 getApp().globalData.urlData = 'data=payErrorData' wx.navigateTo({ url: '/page/home/index', }) }, complete: function (res) { } }) } catch (e) { console.error('支付错误', e) } }

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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// 网页引入jssdk
 
// 网页发起支付
wx.miniProgram.navigateTo({
    // payData由后台返回,主要是需要统一下单平台的prepay_id
    url: '../pay/index?data=' + encodeURIComponent(JSON.stringify(payData))
})
// 微信支付页面
onLoad: function (option) {
    let page = this
    try {
      let data = JSON.parse(option.data)
      if (!data || !data.prepay_id) {
        console.error('支付参数错误,请稍后重试', data)
      }
      wx.requestPayment({
        timeStamp: '' + data.timestamp,
        nonceStr: data.nonceStr,
        package: 'prepay_id=' + data.prepay_id,
        paySign: data.paySign,
        signType: data.signType,
        success: function (res) {
          getApp().globalData.urlToken = `paySuccess.html`
          // 支付成功
          getApp().globalData.urlData = 'data=paySuccessData'
          wx.navigateTo({
            url: '/page/home/index',
          })
        },
        fail: function (res) {
          getApp().globalData.urlToken = `payError.html`
          // 支付失败
          getApp().globalData.urlData = 'data=payErrorData'
          wx.navigateTo({
            url: '/page/home/index',
          })
        },
        complete: function (res) {
        }
      })
    } catch (e) {
      console.error('支付错误', e)
    }
  }

下边介绍登入页面包车型大巴逻辑代码:

complete: function() {

2.index.wxml

直白放到须要展现授权页的onload里

onLoad: function (options) {

      //登陆授权部分逻辑

      var that = this

      var title = arguments[2] ? arguments[2] : '授权登陆战败,部分机能将无法运用,是或不是再次登陆?';//当客商撤销授权登入时,弹出的料定框文案

      var user = wx.getStorageSync('user');//登录过后,客户新闻会缓存

      console.log(user)

      if (!user) {

        console.log(!user)

        // 弹出授权页

        wx.login({

          success: function (res) {

            console.log('弹出授权页成功')

            var code = res.code;

            // 是还是不是同意授权

            wx.getUserInfo({

              success: function (res) { //客户点击 “同意”

                console.log('允许授权:')

                wx.setStorageSync("user", res)//本地缓存user数据  下一次开荒无需登入

                var app = getApp()

                app.globalData.user = res//在当前的app对象中缓存user数据

                // 同步音信到页面

                that.setData({

                  userInfo: app.globalData.user.userInfo

                })         

              },

              fail: function (res) { //顾客点击 “拒绝”

                console.log('拒绝授权')

                wx.showModal({  //自定义弹框展现是还是不是再次同意授权

                  title: '提示',

                  content: title,

                  showCancel: true,

                  cancelText: "否",

                  confirmText: "是",

                  success: function (res) { //调用模态弹窗成功

                    if (res.confirm) { //尽管客户重新同意了授权登入

                      if (wx.openSetting) {  //当前微信的版本 ,是还是不是扶助openSetting,调出小程序设置页面,开启授权

                        wx.openSetting({

                          success: (res) => {

                            if (res.authSetting["scope.userInfo"]) {

                              console.log('客户重新同意授权')

                              wx.getUserInfo({  //跟下面的wx.getUserInfo管理逻辑同样

                                success: function (res) {

                                    wx.setStorageSync("user", res)                           

                                    var app = getApp()

                                    app.globalData.user = res

                                    that.setData({

                                      userInfo: app.globalData.user.userInfo

                                    })

                                }

                              })

                            } else {  //照旧驳回

                              console.log('客商依旧驳回授权,登录失利,此处应该转变页面')

                            }

                          },

                          fail: function () {  //调用失利,授权登入不成功

                            console.log('登入退步')

                          }

                        })

                      } else {

                        console.log('当前客商微信版本不协理openSetting,登入战败')

                      }

                    }else{

                      //能够在那边丰盛贰个承认授权的页面,借使不想加的话,就须求每趟跳转到那个页面都质量评定一次是或不是授权,那么这些函数就应该放手任何钩子函数里了

                      console.log('客户第一回拒绝了授权,在这里转换页面')

                    }

                  }

                })

              }

            })

          }

        })

      } else {//即便缓存中早已存在user  那就是已经报到过

        var app = getApp()

        app.globalData.user = user

      } 

  }

也可以把它封装成二个函数,用的时候调用就能够了

openid登陆难题

微信webview的使用格局很简单,只要如下设置src就足以来得具体的网址了。

<!-- wxml --> <!-- 指向微信大伙儿平台首页的web-view --> <web-view src=";

1
2
3
<!-- wxml -->
<!-- 指向微信公众平台首页的web-view -->
<web-view src="https://mp.weixin.qq.com/"></web-view>

微信碰着里的好多网页都是用页面要兑现网址的报到功用,只要把登陆的新闻,比方openid可能别的音信拼接到src里就好了。

此地有个难点,公众号的账号体系一般是以openid来剖断独一性的,小程序是足以博得openid的,但是小程序的openid和原公众号之类的openid是不等同的,须求将原本的openid账号种类进级为unionid账号连串。

以下是微信对unionid的牵线

收获客商基本音讯(UnionID机制)

在关切者与民众号产生消息交互后,大伙儿号可收获关心者的OpenID(加密后的微能量信号,每一种客户对各类公众号的OpenID是头一无二的。对于不相同民众号,同一客商的openid分裂)。公众号可通过本接口来依照OpenID获取顾客中央音讯,满含小名、头像、性别、所在城市、语言和敬服时间。

请留意,假使开垦者有在七个公众号,或在群众号、移动接纳之间联合客商帐号的要求,必要前往微信开放平台(open.weixin.qq.com)绑定大伙儿号后,才可接纳UnionID机制来满足上述必要。

UnionID机制表明:

开采者可由此OpenID来赢得客户宗旨新闻。极度必要留神的是,借使开采者具有四个活动选择、网址使用和大伙儿帐号,可透过得到客户焦点新闻中的unionid来分裂客商的独一性,因为借使是同三个微信开放平台帐号下的活动使用、网址选择和大伙儿帐号,顾客的unionid是独一的。换句话说,同一客户,对同三个微信开放平台下的例外应用,unionid是一样的。

做完以上步骤,就足以调用小程序api wx.getUserInfo() 来赢得顾客新闻了,此步骤需求开展后台音讯解密进度,在此就不再赘言,结合小程序api文档操作就好。

获得到unioid之后,将unionid新闻拼接到src就足以拓宽网页登陆操作了(前提是网页能够用跳转链接的不二法门登入,类似公众号页面获得openid的花样)。

PS:需求思量的主题材料是,在其余页面,怎么才干理解是否业已酿成报到了啊?

data: { x:'', y:''},

demo中已经写出:

围观普通二维码跳转特定页面

除外享受功用之外,小程序还足以因此配备,落成扫描普通二维码跳转特定页面包车型大巴成效。

以下是微信对此意义的牵线

为了便于小程序开拓者更省心地扩充小程序,兼容线下已部分二维码,微信公众平台开放扫描普通链接二维码跳转小程序技艺。

职能介绍

普通链接二维码,是指开荒者使用工具对网页链接举行编码后生成的二维码。

线下商家可不需改换线下二维码,在小程序后台完成布局后,就可以在客商扫描普通链接二维码时展开小程序,使用小程序的效率。
对于普通链接二维码,近年来支撑采用微信“扫一扫”或微信内长按识别二维码跳转小程序.

二维码法则

基于二维码跳转法则,开采者须求填写须要跳转小程序的二维码法则。供给如下:

  1. 二维码法规的域名须经过ICP备案的印证。
  2. 支撑http、https、ftp伊始的链接(如:、)。
  3. 贰个小程序帐号可配置十分少于11个二维码前缀法规。

前缀占用准绳

开辟者可挑选是还是不是占用符合二维码相配准绳的全部子法规。如采纳占用,则别的帐号不可申请使用满意该前缀相称法则的别样子准绳。

如:若开采者A配置二维码法规:,并选拔“占用全数子准则“,别的开采者将不得以布置满意前缀相配的杜鹃则如。

本人推荐的措施

webview完结格局

  1. 安装跳转功能小程序后台就足以设置,链接是分为四某个,路https://www.example.com/wxmin…。

    https://www.example.com 域名
    /wxmini/ 小程序前置规则,需要在服务器上建一个文件夹,并且把验证文件放在文件夹线
    home.html 需要跳转的网页页面
    a=1 跳转页面的参数
  2. 对onload函数再拓展管理,实现平日二维码跳转。

JavaScript

// 对index onLoad在扩充拍卖 onLoad: function (option) { this.resetOption(option) if (option.urlToken) { getApp().globalData.urlToken = option.urlToken } if (option.urlData) { getApp().globalData.urlData = option.urlData } this.setData({ url: getApp().globalData.urlToken + '?' + getApp().globalData.urlData }) }, resetOption: function (option) { if (!option) { return } if (option.q) { option.q = decodeURIComponent(option.q) if (option.q.indexOf('') == -1) { return } let tmp = option.q.replace('/wxmini', '') let tmps = tmp.split('?') option.urlToken = tmps[0] option.urlData = tmps[1] } else { option.urlData = decodeURIComponent(option.urlData) } }

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
// 对index onLoad在进行处理
onLoad: function (option) {
    this.resetOption(option)
    if (option.urlToken) {
      getApp().globalData.urlToken = option.urlToken
    }
    if (option.urlData) {
      getApp().globalData.urlData = option.urlData
    }
    this.setData({
      url: getApp().globalData.urlToken + '?' +  getApp().globalData.urlData
    })
},
resetOption: function (option) {
    if (!option) {
      return
    }
    if (option.q) {
      option.q = decodeURIComponent(option.q)
      if (option.q.indexOf('https://www.example.com/wxmini/') == -1) {
        return
      }
      let tmp = option.q.replace('/wxmini', '')
      let tmps = tmp.split('?')
      option.urlToken = tmps[0]
      option.urlData = tmps[1]
    } else {
      option.urlData = decodeURIComponent(option.urlData)
    }
}

图片 1签到回调

多少绑定使用 Mustache 语法(双大括号)将变量包起来。

1.index.js

参照他事他说加以考察链接

  1. webview文档
  2. 小程序unionid介绍
  3. unionid获得情势

    2 赞 2 收藏 评论

图片 2

图片 3login页面,点击按键完毕报到

"selectedIconPath":"public/center.png"

 

遇见的主题素材

  1. openid登入难题
  2. webview动态src
  3. 付出功效
  4. 享用功效
  5. 举目四望普通二维码跳转特定页面
  6. 归来开关缺点和失误难点

到此地,要求点击按键本事触发登陆已消除。

}

  1. <!--newpage.wxml-->  
  2. <view style="width:100%;margin:30rpx">infofromapp:{{infofromapp}}</view>  
  3. <view style="width:100%;margin:30rpx">infofromindex:{{infofromindex}}</view>  
  4. <view style="width:100%;margin:30rpx">infofromstorage:{{infofromstorage}}</view>  

享用功用

小程序直接分享的webview所在的页面,假如须求增加页面参数,那大家就需求管理一下了。

  1. webview内是不能直接发起分享的,需求先用wx.miniProgram.postMessage接口,把供给分享的音信,推送给小程序;推送给小程序的新闻不是实时管理的,而是客户点击了享受按键之后,小程序才回到读取的,那将要求每一种须求分享的页面再踏向的时候就发起wx.miniProgram.postMessage推送分享音讯给小程序。
  2. 小程序页面通过bindmessage绑定的函数读取post音讯,分享的消息会是三个列表,我们取尾数享用就好,把分享音信管理好,存到data里面以便下一步onShareAppMessage调用。
  3. 客户点击分享时,会触发onShareAppMessage函数,在其间安装好相应的享用音讯就好了。
  4. onload函数有三个option参数的,能够读取页面加载时url里带的参数,那时要对本来的onload函数进行改建,实现从option里读取链接音讯。

JavaScript

// 网页wx.miniProgram.postMessage wx.miniProgram.postMessage({ data: { link: shareInfo.link, title: shareInfo.title, imgUrl: shareInfo.imgUrl, desc: shareInfo.desc } }) // 小程序index wxml设置 <web-view src="{{url}}" bindmessage="bindGetMsg"></web-view> // 小程序index js bindGetMsg: function (e) { if (!e.detail) { return } let list = e.detail.data if (!list || list.length === 0) { return } let info = list[list.length - 1] if (!info.link) { console.error('分享音讯错误', list) return } let tokens = info.link.split('?') this.setData({ shareInfo: { title: info.title, imageUrl: info.imgUrl, path: `/page/index/index?urlData=${encodeURIComponent(tokens[1])}&urlToken=${tokens[0]}` } }) }, onShareAppMessage: function (res) { if (res.from === 'button') { // 来自页面内转载按键 console.log(res.target) } let that = this return { title: that.data.shareInfo.title, path: that.data.shareInfo.path, imageUrl: that.data.shareInfo.imageUrl, success: function (res) { // 转载成功 }, fail: function (res) { // 转发退步 } } }, onLoad: function (option) { if (option.urlToken) { getApp().globalData.urlToken = option.urlToken } if (option.urlData) { getApp().globalData.urlData = option.urlData } this.setData({ url: getApp().globalData.urlToken + '?'

  • getApp().globalData.urlData }) },
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// 网页wx.miniProgram.postMessage
wx.miniProgram.postMessage({
  data: {
    link: shareInfo.link,
    title: shareInfo.title,
    imgUrl: shareInfo.imgUrl,
    desc: shareInfo.desc
  }
})
// 小程序index wxml设置
<web-view src="{{url}}" bindmessage="bindGetMsg"></web-view>
// 小程序index js
bindGetMsg: function (e) {
    if (!e.detail) {
      return
    }
    let list = e.detail.data
    if (!list || list.length === 0) {
      return
    }
    let info = list[list.length - 1]
    if (!info.link) {
      console.error('分享信息错误', list)
      return
    }
    let tokens = info.link.split('?')
    this.setData({
      shareInfo: {
        title: info.title,
        imageUrl: info.imgUrl,
        path: `/page/index/index?urlData=${encodeURIComponent(tokens[1])}&urlToken=${tokens[0]}`
      }
    })
},
onShareAppMessage: function (res) {
    if (res.from === 'button') {
      // 来自页面内转发按钮
      console.log(res.target)
    }
    let that = this
    return {
      title: that.data.shareInfo.title,
      path: that.data.shareInfo.path,
      imageUrl: that.data.shareInfo.imageUrl,
      success: function (res) {
        // 转发成功
      },
      fail: function (res) {
        // 转发失败
      }
    }
},
onLoad: function (option) {
    if (option.urlToken) {
      getApp().globalData.urlToken = option.urlToken
    }
    if (option.urlData) {
      getApp().globalData.urlData = option.urlData
    }
    this.setData({
      url: getApp().globalData.urlToken + '?' +  getApp().globalData.urlData
    })
},

login思路:一跻身该页面,从缓存中把上一个页面拿出去(读取后需求破除该缓存),然后把登陆开关设置成获取客商音讯项目,如

{

 

再次回到开关缺点和失误难点

一旦web页面是在首先个页面包车型地铁话,那时候会有一个标题,小程序的回到开关就从不了,webview不恐怕使用微信的归来按键了,那时候只要在webview页前面多加一个跳转页面就好了(第二个页面也足以设置成获取客商权限的页面,不过本身深感那样感受不佳,亦非怀有页面都要客商得到了权力才足以利用)

最后的页面层级

JavaScript

"pages": [ "page/index/index", // 首页,管理onload里的option内容,为了重临开关设置的 "page/home/index", // webview所在的页面 "page/auth/index", // 获取顾客权限的页面 "page/pay/index", // 支付页面 "page/error/index" // 错误新闻页面 ],

1
2
3
4
5
6
7
"pages": [
    "page/index/index", // 首页,处理onload里的option内容,为了返回按钮设置的
    "page/home/index", // webview所在的页面
    "page/auth/index", // 获取用户权限的页面
    "page/pay/index", // 支付页面
    "page/error/index" // 错误信息页面
  ],

const Request = require("/utils/request"); //引进封装的http拦截器

App({

onLaunch: function {

this.authorize(options.query); // 直接授权登入(options.query 参数与分享配置有关,后续小说介绍)

},

authorize: function {

let self = this;

share = share || {};

wx.login({

success: function {

wx.getUserInfo({

success: function {

Request.post("/api/xcxWxLogin", {

code: res.code,

encryptedData: resp.encryptedData,

iv: resp.iv

}).then(({

data: response

}) => {

if (response.code !== 0) {

wx.showToast({

title: response.msg,

icon: "none"

});

} else {

// 保存sessionid ,每回恳求都会在拦截器中自行增多到header中

wx.setStorageSync("UserSessionId", response.data.sessionId);

self.globalData.sessionid = response.data.sessionId;

//todo 后续逻辑代码

}

});

},

fail: function {

//珍视,若是获得失利直接跳转

let timer = setInterval => {

let pages = getCurrentPages();

if (pages.length > 0) {

clearInterval;

let currentPage = pages[pages.length - 1];

if (currentPage.route === "pages/user/userbind/userbind") {

return true;

}

try {

wx.setStorageSync("SYS_PREVIOUSPAGE", currentPage);

setTimeout => {

wx.redirectTo({

url: "/pages/login/login"

});

}, 300);

} catch {

wx.redirectTo({

url: "/pages/login/login"

});

}

}

}, 200);

}

});

}

});

}

})

})

4.newpage.wxml

webview动态src

微信的webview有个坑的地方,不会动态的监听src的变型,那就导致了多个主题材料,要经过退换src达成页面跳转就不可以了。
本身尝试了一部分办法之后,找到了叁个缓和方案:

微信webview在页面load的时候会加载叁次webview,大家就使用那几个特点来落到实处动态src难点。

  1. 第一把要跳转的链接新闻设置成全局变量,要改成src的时候,先把要src以’?‘拆分为链接和参数两部分,存入全局函数,再调用onLoad就能够达成webview刷新了。
  2. 页面跳转时,我们也须求src的动态刷新,所以要把链接音信存入全局函数;页面跳转时,onShow函数会被调用,这时候再调用叁回onLoad就足以了。

data: { url: '', loaded: false } // 小程序js里的onLoad函数能够写成这么 onLoad: function () { this.setData({ url: getApp().globalData.urlToken + '?' + getApp().globalData.urlData }) }, changUrl: function () { getApp().globalData.urlToken = '' getApp().globalData.urlToken = 'a=1&b=2' // 直接调用onLoad,就能够促成src的刷新 this.onLoad() }, onShow: function () { if (!this.data.loaded) { // 第一次不运营 this.setData({ loaded: true }) return } // 直接调用onLoad,就能够落到实处src的基础代谢 this.onLoad() } // wxml能够写成这么 <web-view src="{{url}}"></web-view>

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
data: {
    url: '',
    loaded: false
}
// 小程序js里的onLoad函数可以写成这样
onLoad: function () {
    this.setData({
      url: getApp().globalData.urlToken + '?' +  getApp().globalData.urlData
    })
},
changUrl: function () {
    getApp().globalData.urlToken = 'https://www.example.com'
    getApp().globalData.urlToken = 'a=1&b=2'
    // 直接调用onLoad,就会实现src的刷新
    this.onLoad()
},
onShow: function () {
    if (!this.data.loaded) {
      // 第一次不运行
      this.setData({
        loaded: true
      })
      return
    }
    // 直接调用onLoad,就会实现src的刷新
    this.onLoad()
  }
 
// wxml可以写成这样
<web-view src="{{url}}"></web-view>

最近,微信官方修改了 getUserInfo、authorize等 接口,无法直接弹出授权窗口,那让大家原先一起始就拿走顾客音信达成报到的效率全体失效,新明确是第三次拿走客户音讯只可以通过 button 去接触,那么有啥技术方案吧?

1、保留当前页面,跳转到应用内的有些页面,使用wx.navigateBack可以重回到原页面。

2. wx.navigateTo({})中U牧马人L带领参数

网页程序迁移至微信小程序web-view详解

2018/08/02 · JavaScript · 小程序

原稿出处: NeoPasser   

小程序今后更是流行,可是集团的非常多门类都以用网页写的,小程序语法不相配原生网页,使得旧有档案的次序搬迁至小程序代价相当高。

小程序之前开放了webview功用,可以说是网页应用的第一次全国代表大会福音了,可是微信的webview有一对坑,那篇作品便是列举一下自家在付出进程中相见的一对题目以及自个儿找到的一些减轻方案。

点击登陆开关后触发bindgetuserinfo回调,在回调中推断是不是授权,未有一点点击分明授权就提醒要授权,有授权就直接调用app.js的授权方法,最终重定向到上八个页面(是重定向不是回去,而且亟需静心是否导航页面

调节属性:<view wx:if="{{condition}}"></view>

②获取数据

赢得顾客消息成功的回调具体得看业务,获取败北的回调主假若加放大计时器去看清页面是或不是加载成功,加载成功后再保存当前页面路线(用于登入成功后跳转),最终跳转到一个暗含登陆开关的页面(不在app.js中成功报到,而是在login.js中成就报到,第三次张开就静默授权了)

"navigationBarTitleText":"二个标题而已",

贴上代码:

图片 4设置签到开关

},{

  1. //newpage.js  
  2. //获取使用实例  
  3. var app = getApp()  
  4. Page({  
  5.     data: {  
  6.         infofromapp: app.data.infofromapp,  
  7.         infofromindex: '',  
  8.         infofromstorage: '',  
  9.     },  
  10.     onLoad: function (options) {  
  11.         var _this = this;  
  12.         var infofromindex = options.infofromindex;  
  13.         this.setData({  
  14.             infofromindex: infofromindex  
  15.         })  
  16.         //获取  
  17.         wx.getStorage({  
  18.             key: 'infofrominput',  
  19.             success: function (res) {  
  20.                 _this.setData({  
  21.                     infofromstorage: res.data,  
  22.                 })  
  23.             }  
  24.         })  
  25.     }  
  26. })  

实际代码如下:

"list": [{

 

作者的笔触是一步入小程序的时候,立马去调用登陆接口(wx.login,在此以前的代码不用变)并在回调中去调用获取顾客音信接口(wx.getUserInfo),那时候就须求极度注意了,必要会wx.getUserInfo的获得失利钩子举办判别,假使失利,那么直接跳转去登入页面(登入页面中能够兑现开关登入);借使成功,继续延续逻辑代码。

}],

[javascript] view plain copy

const Request = require("../../utils/request");

Page({

/**

* 页面包车型地铁初叶数据

*/

data: {

route: "/pages/home/home"

},

/**

* 生命周期函数--监听页面加载

*/

onLoad: function {

let self = this;

wx.getStorage({

key: "SYS_PREVIOUSPAGE",

success: function {

if (res.errMsg === "getStorage:ok") {

self.setData({

route: "/" + res.data.route,

share: res.data.options

});

}

wx.removeStorage({

key: "SYS_PREVIOUSPAGE"

});

}

});

},

bindgetuserinfo: function {

if (e.detail.errMsg.indexOf > -1) {

wx.showModal({

title: '温馨提示',

content: '您未同意授权,系统无法检查测量检验你的地位,请允许授权',

});

} else {

getApp().authorize(this.data.share);

setTimeout => {

if (["/pages/home/home", "/pages/course/courselist/courselist", "/pages/course/publiclist/publiclist", "/pages/consult/consultlist/consultlist", "/pages/usercenter/usercenter"].indexOf(this.data.route) > -1) {

wx.switchTab({

url: this.data.route

});

} else {

wx.redirectTo({

url: this.data.route

});

}

}, 800);

}

}

})

,

①仓库储存数据

complete: function() {

 

},

 

内容:<view>{{message}}</view>

 

"pages/index/index",

页面间传递参数的笔记

跳转:

 

"iconPath":"public/hot-cd.png",

 

"pagePath":"pages/center/center",

今昔已知传递参数的秘诀只找到二种,先计算下.由杨晓培处在内部测量检验阶段,文书档案亦非很平稳,日常修改,目前尚未有人工轮子.

// complete

 

本文由必威发布于必威-前端,转载请注明出处:但是公司的很多项目都是用网页写的,也没有类

TAG标签:
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。