-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
95 lines (91 loc) · 2.38 KB
/
app.js
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
//app.js
App({
fetch: require('utils/fetch.js'),
onLaunch: function () {
wx.showLoading({
title: '登录中...',
mask: true
})
this.fetch('user/setting').then( data => {
console.log(data)
if (data.isLogin) {
// 已登录
this.onUserInfoReady();
console.log('通过保存的cookie登陆成功')
} else {
// 未登录
this.login({
success: () => {
// 登陆成功
this.onUserInfoReady();
// wx.hideLoading()
console.log('登陆成功')
},
fail: () => {
// 登录失败,说明服务器异常,已经弹出模态框,这里用来重试
this.onLaunch()
}
})
}
},() => {
this.onLaunch()
})
// 登录
wx.login({
success: res => {
// 发送 res.code 到后台换取 openId, sessionKey, unionId
}
})
// 获取用户信息
wx.getSetting({
success: res => {
if (res.authSetting['scope.userInfo']) {
// 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
wx.getUserInfo({
success: res => {
// 可以将 res 发送给后台解码出 unionId
this.globalData.userInfo = res.userInfo
// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
// 所以此处加入 callback 以防止这种情况
if (this.userInfoReadyCallback) {
this.userInfoReadyCallback(res)
}
}
})
}
}
})
this.globalData = {}
},
login: function(options) {
wx.login({
success: res => {
// 获得 res.data
this.fetch('user/login', {
js_code: res.code
}).then(data => {
// 判断是否成功
if (data && data.isLogin) {
// 登录成功
options.success()
} else {
// 登录失败
options.fail()
}
}, () => {
// 登录失败,服务器异常
options.fail()
})
}
})
},
userInfoReady: false,
onUserInfoReady: function() {
wx.hideLoading();
if (this.userInfoReadyCallback) {
this.userInfoReadyCallback();
}
this.userInfoReady = true
console.log(2222)
}
})