1 Star 0 Fork 45

小刀/uni-app-mall_1

forked from javazj/uni-app-mall 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
App.vue 6.31 KB
一键复制 编辑 原始数据 按行查看 历史
javazj 提交于 2022-06-29 17:42 . version 2.0.0
<script>
const WXAUTH = require('@/common/wxauth.js')
const TTAUTH = require('@/common/ttauth.js')
const QQAUTH = require('@/common/qqauth.js')
export default {
globalData: {
h5Domain: 'https://flpt.jxsupplier.com',
goLogin: false,
subDomain: 'tz', // jdjf0115
merchantId: 951, // 42151
version: '2.0.0',
sysconfigkeys: 'mallName,shopMod,share_profile,recharge_amount_min,open_growth,shopping_cart_vop_open,needIdCheck',
wxpayOpenAppId: 'wx9b04553fd8c7b9c3', // 微信开放平台的移动端应用appID
openAlipayProvider: false, // 是否开通支付宝支付
addressLevel: 3, // 省市区到3级还是4级,可选 3 或者 4
},
onLaunch: function() {
// https://www.yuque.com/apifm/nu0f75/cdqz1n
this.$wxapi.setMerchantId(this.globalData.merchantId)
this.$wxapi.init(this.globalData.subDomain)
const _this = this
// 1.1.0版本之前关于http拦截器代码,已平滑移动到/common/http.interceptor.js中
// 注意,需要在/main.js中实例化Vue之后引入如下(详见文档说明):
// import httpInterceptor from '@/common/http.interceptor.js'
// Vue.use(httpInterceptor, app)
// process.env.VUE_APP_PLATFORM 为通过js判断平台名称的方法,结果分别如下:
/**
* h5,app-plus(nvue下也为app-plus),mp-weixin,mp-alipay......
*/
this.checkForUpdate(); // 检查新版本
this.queryConfigBatch();
},
onShow(e) {
if (e && e.query && e.query.inviter_id) {
this.$u.vuex('referrer', e.query.inviter_id)
}
if (e && e.query && e.query.code) {
// 微信登陆
this.wxmpLogin(e.query.code)
return
} else {
this.autoLogin()
}
},
onHide: function() {
// console.log('App Hide,app不再展现在前台')
},
onPageNotFound(e) {
// 页面不存在 {path: '/1212', query: {a: '123'}, isEntryPage: true}
console.error(e)
},
methods: {
async queryConfigBatch() {
const sysconfigkeys = this.globalData.sysconfigkeys
if (!sysconfigkeys) {
return
}
// https://www.yuque.com/apifm/nu0f75/dis5tl
const res = await this.$wxapi.queryConfigBatch(sysconfigkeys)
if (res.code == 0) {
const sysconfigMap = {}
res.data.forEach(config => {
sysconfigMap[config.key] = config.value
})
this.$u.vuex('sysconfigMap', sysconfigMap)
}
},
checkForUpdate() {
// #ifdef MP
const updateManager = uni.getUpdateManager();
updateManager.onCheckForUpdate(function(res) {
// 请求完新版本信息的回调
console.log(res.hasUpdate);
});
updateManager.onUpdateReady(function(res) {
uni.showModal({
title: '更新提示',
content: '新版本已经准备好,是否重启应用?',
success(res) {
if (res.confirm) {
// 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
updateManager.applyUpdate();
}
}
});
});
updateManager.onUpdateFailed(function(res) {
// 新的版本下载失败
});
// #endif
// #ifdef APP-PLUS
// APP 自动更新
// #endif
},
async autoLogin() {
// 自动登陆
// #ifdef MP-WEIXIN
const isLogined = await WXAUTH.checkHasLogined()
if (!isLogined) {
await WXAUTH.authorize()
await WXAUTH.bindSeller()
}
setTimeout(() => {
uni.$emit('loginOK', {})
}, 500)
// #endif
// #ifdef MP-QQ
const isLogined = await QQAUTH.checkHasLogined()
if (!isLogined) {
await QQAUTH.authorize()
await QQAUTH.bindSeller()
}
setTimeout(() => {
uni.$emit('loginOK', {})
}, 500)
// #endif
// #ifdef MP-TOUTIAO
const isLogined = await TTAUTH.checkHasLogined()
if (!isLogined) {
await TTAUTH.authorize()
await TTAUTH.bindSeller()
}
setTimeout(() => {
uni.$emit('loginOK', {})
}, 500)
// #endif
// #ifdef H5
const isLogined = await this.checkHasLoginedH5()
if (!isLogined) {
// 判断是普通浏览器还是微信浏览器
const ua = window.navigator.userAgent.toLowerCase();
if (ua.match(/MicroMessenger/i) == 'micromessenger') {
// 微信内置浏览器打开的
// https://www.yuque.com/apifm/nu0f75/fpvc3m
const res = await this.$wxapi.siteStatistics()
const wxMpAppid = res.data.wxMpAppid
let _domian = this.globalData.h5Domain + '/pages/index/index'
_domian = encodeURIComponent(_domian)
console.log(_domian);
if (!this.globalData.goLogin) {
this.globalData.goLogin = true
window.parent.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=' +
wxMpAppid + '&redirect_uri=' + _domian +
'&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect'
}
} else {
// 其他浏览器打开的, 按需登陆,不能直接跳转到登陆界面
// uni.navigateTo({
// url: "/pages/login/login"
// })
}
}
// #endif
},
async checkHasLoginedH5() {
const _this = this.$vm ? this.$vm : this
if (!_this.token) {
return false
}
// https://www.yuque.com/apifm/nu0f75/mp9f59
const res = await _this.$wxapi.checkToken(_this.token)
if (res.code != 0) {
_this.$u.vuex('token', '')
return false
}
return true
},
async wxmpLogin(code) {
// https://www.yuque.com/apifm/nu0f75/lh6cd3
const res = await this.$wxapi.wxmpAuth({
code
})
if (res.code == 0) {
this.$u.vuex('token', res.data.token)
this.$u.vuex('uid', res.data.uid)
this.$u.vuex('openid', res.data.openid)
setTimeout(() => {
uni.$emit('loginOK', {})
}, 500)
}
}
}
}
</script>
<style lang="scss">
/*每个页面公共css */
@import "@/uni_modules/uview-ui/index.scss";
.price-score {
display: flex;
color: #e64340;
font-size: 38rpx;
text {
padding: 0 4rpx;
font-size: 28rpx;
}
.item {
padding: 0 8rpx;
display: flex;
align-items: center;
}
.original {
margin-left: 32rpx;
color: #aaa;
text-decoration: line-through
}
.score-icon {
width: 28rpx;
height: 28rpx;
}
}
.goods-title-tag {
display: inline-flex !important;
margin-right: 24rpx;
}
.goods-title {
color: #333;
font-size: 28rpx;
}
.pt16 {
padding-top: 16rpx !important;
}
.submit-btn {
padding: 32rpx;
}
.form-box {
padding: 32rpx;
}
.mt32 {
margin-top: 32rpx;
}
</style>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/wyby/uni-app-mall_1.git
[email protected]:wyby/uni-app-mall_1.git
wyby
uni-app-mall_1
uni-app-mall_1
main

搜索帮助