修复一些缺陷,更换tabbar素材
|
@ -2,10 +2,19 @@
|
|||
// launchtype项可配置值为local或remote, local代表前端连本地云函数,remote代表前端连云端云函数
|
||||
"version": "0.0",
|
||||
"configurations": [{
|
||||
"type": "uniCloud",
|
||||
"default": {
|
||||
"launchtype": "remote"
|
||||
}
|
||||
}
|
||||
"default" :
|
||||
{
|
||||
"launchtype" : "remote"
|
||||
},
|
||||
"h5" :
|
||||
{
|
||||
"launchtype" : "remote"
|
||||
},
|
||||
"mp-weixin" :
|
||||
{
|
||||
"launchtype" : "remote"
|
||||
},
|
||||
"type" : "uniCloud"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
|
@ -1,6 +1,5 @@
|
|||
<template>
|
||||
<!-- v-if="reply.length>0" -->
|
||||
<view class="evaluateWtapper">
|
||||
<view class="evaluateWtapper" v-if="reply.length > 0">
|
||||
<view class="evaluateItem" v-for="(item, indexw) in reply" :key="indexw">
|
||||
<view class="pic-text acea-row">
|
||||
<view class="pictrue">
|
||||
|
@ -39,7 +38,7 @@
|
|||
props: {
|
||||
reply: {
|
||||
type: Array,
|
||||
default: () => []
|
||||
default: []
|
||||
}
|
||||
},
|
||||
data: function() {
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
|
||||
let domain = 'http://127.0.0.1:8080'
|
||||
let domain = 'https://api.dev.java.crmeb.net/'
|
||||
|
||||
module.exports = {
|
||||
// 请求域名 格式: https://您的域名
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"name" : "crmeb",
|
||||
"appid" : "__UNI__66E0853",
|
||||
"appid" : "__UNI__E8BDBA5",
|
||||
"description" : "crmeb商城",
|
||||
"versionName" : "1.0.0",
|
||||
"versionCode" : 1001,
|
||||
|
@ -99,11 +99,7 @@
|
|||
},
|
||||
"domain" : "",
|
||||
"sdkConfigs" : {
|
||||
"maps" : {
|
||||
"qqmap" : {
|
||||
"key" : "map key"
|
||||
}
|
||||
}
|
||||
"maps" : {}
|
||||
},
|
||||
"optimization" : {
|
||||
"treeShaking" : {
|
||||
|
|
|
@ -276,6 +276,7 @@
|
|||
import {
|
||||
getProductCode
|
||||
} from '@/api/store.js'
|
||||
import { spread } from "@/api/user";
|
||||
export default {
|
||||
components: {
|
||||
shareRedPackets,
|
||||
|
@ -417,18 +418,27 @@
|
|||
},
|
||||
});
|
||||
if (options.hasOwnProperty('id') || options.scene) {
|
||||
options.scene ? this.id = app.globalData.id : this.id = options.id;
|
||||
// app.globalData.openPages = '/pages/activity/goods_combination_details/index?id=' + this.id + '&spid=' + this.userInfo.uid;
|
||||
if (options.scene) { // 仅仅小程序扫码进入
|
||||
let qrCodeValue = this.$util.getUrlParams(decodeURIComponent(options.scene));
|
||||
let mapeMpQrCodeValue = this.$util.formatMpQrCodeData(qrCodeValue);
|
||||
app.globalData.spread = mapeMpQrCodeValue.spread;
|
||||
this.id = mapeMpQrCodeValue.id;
|
||||
setTimeout(()=>{
|
||||
spread(mapeMpQrCodeValue.spread).then(res => {}).catch(res => {})
|
||||
},2000)
|
||||
}else{
|
||||
this.id = options.id;
|
||||
}
|
||||
if (this.isLogin) {
|
||||
this.combinationDetail();
|
||||
} else {
|
||||
// #ifdef H5
|
||||
// #ifdef H5 || APP-PLUS
|
||||
try {
|
||||
uni.setStorageSync('comGoodsId', options.id);
|
||||
} catch (e) {}
|
||||
// #endif
|
||||
this.$Cache.set('login_back_url',
|
||||
`/pages/activity/goods_combination_details/index?id=${options.id}&spid=${options.spid?options.spid:0}`
|
||||
`/pages/activity/goods_combination_details/index?id=${options.id}&spread=${options.pid?options.pid:0}`
|
||||
);
|
||||
toLogin();
|
||||
}
|
||||
|
@ -448,7 +458,6 @@
|
|||
})
|
||||
}
|
||||
};
|
||||
this.isLogin && silenceBindingSpread();
|
||||
},
|
||||
methods: {
|
||||
getProductReplyCount: function() {
|
||||
|
|
|
@ -112,7 +112,6 @@
|
|||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<!-- <shareRedPackets :sharePacket="sharePacket" @listenerActionSheet="listenerActionSheet" @closeChange="closeChange"></shareRedPackets> -->
|
||||
<product-window :attr='attribute' :limitNum='1' @myevent="onMyEvent" @ChangeAttr="ChangeAttr" @ChangeCartNum="ChangeCartNum"
|
||||
@attrVal="attrVal" @iptCartNum="iptCartNum"></product-window>
|
||||
<!-- #ifdef MP -->
|
||||
|
@ -200,6 +199,7 @@
|
|||
toLogin
|
||||
} from '@/libs/login.js';
|
||||
import { silenceBindingSpread } from "@/utils";
|
||||
import { spread } from "@/api/user";
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
|
@ -311,7 +311,7 @@
|
|||
}
|
||||
},
|
||||
onLoad(options) {
|
||||
let that = this
|
||||
let that = this;
|
||||
that.$store.commit("PRODUCT_TYPE", 'normal');
|
||||
let statusBarHeight = '';
|
||||
var pages = getCurrentPages();
|
||||
|
@ -330,16 +330,38 @@
|
|||
let menuButtonInfo = uni.getMenuButtonBoundingClientRect()
|
||||
this.meunHeight = menuButtonInfo.height
|
||||
this.backH = (that.navH / 2) + (this.meunHeight / 2)
|
||||
|
||||
setTimeout(()=>{
|
||||
if(options.spread){
|
||||
app.globalData.spread = options.spread;
|
||||
spread(options.spread).then(res => {})
|
||||
}
|
||||
},2000)
|
||||
if (!options.scene && !options.id){
|
||||
this.showSkeleton = false;
|
||||
this.$util.Tips({
|
||||
title: '缺少参数无法查看商品'
|
||||
}, {
|
||||
url: '/pages/index/index'
|
||||
});
|
||||
return;
|
||||
}
|
||||
if (options.hasOwnProperty('id') || options.scene){
|
||||
if (options.scene) { // 仅仅小程序扫码进入
|
||||
let qrCodeValue = this.$util.getUrlParams(decodeURIComponent(options.scene));
|
||||
let mapeMpQrCodeValue = this.$util.formatMpQrCodeData(qrCodeValue);
|
||||
app.globalData.spread = mapeMpQrCodeValue.spread;
|
||||
this.id = mapeMpQrCodeValue.id;
|
||||
setTimeout(()=>{
|
||||
spread(mapeMpQrCodeValue.spread).then(res => {}).catch(res => {})
|
||||
},2000)
|
||||
}else{
|
||||
this.id = options.id;
|
||||
}
|
||||
}
|
||||
// #endif
|
||||
if (!options.scene && options.id == 'undefined') return this.$util.Tips({
|
||||
title: '缺少参数无法查看商品'
|
||||
}, {
|
||||
tab: 3,
|
||||
url: 1
|
||||
});
|
||||
options.scene ? this.id = app.globalData.id : this.id = options.id;
|
||||
|
||||
if (this.isLogin) {
|
||||
this.id = options.id;
|
||||
this.getSeckillDetail();
|
||||
} else {
|
||||
this.$Cache.set('login_back_url',
|
||||
|
@ -372,7 +394,7 @@
|
|||
limit: 3,
|
||||
type: 0,
|
||||
}).then(res => {
|
||||
this.reply = res.data.list ? [res.data.list[0]] : [];
|
||||
this.reply = res.data.list;
|
||||
})
|
||||
},
|
||||
getProductReplyCount: function() {
|
||||
|
|
|
@ -269,6 +269,7 @@
|
|||
getProductGood,
|
||||
getReplyProduct
|
||||
} from '@/api/store.js';
|
||||
import { spread } from "@/api/user";
|
||||
import {
|
||||
getCoupons
|
||||
} from '@/api/api.js';
|
||||
|
@ -425,38 +426,48 @@
|
|||
if (pages.length <= 1) {
|
||||
that.retunTop = false
|
||||
}
|
||||
// #ifdef MP
|
||||
that.navH = app.globalData.navHeight;
|
||||
// #ifdef MP || APP-PLUS
|
||||
// 小程序链接进入获取绑定关系id
|
||||
setTimeout(()=>{
|
||||
if(options.spread){
|
||||
app.globalData.spread = options.spread;
|
||||
spread(options.spread).then(res => {})
|
||||
}
|
||||
},2000)
|
||||
// #endif
|
||||
// #ifndef MP
|
||||
that.navH = 96;
|
||||
// #endif
|
||||
if (options.id == 'undefined') {
|
||||
that.id = 0
|
||||
} else {
|
||||
that.id = options.id;
|
||||
uni.getSystemInfo({
|
||||
success: function(res) {
|
||||
that.height = res.windowHeight;
|
||||
},
|
||||
});
|
||||
if (!options.scene && !options.id) {
|
||||
this.showSkeleton = false;
|
||||
this.$util.Tips({
|
||||
title: '缺少参数无法查看商品'
|
||||
}, {
|
||||
url: '/pages/index/index'
|
||||
});
|
||||
return;
|
||||
}
|
||||
if (options.hasOwnProperty('id') || options.scene) {
|
||||
if (options.scene) { // 仅仅小程序扫码进入
|
||||
let qrCodeValue = that.$util.getUrlParams(decodeURIComponent(options.scene));
|
||||
let mapeMpQrCodeValue = that.$util.formatMpQrCodeData(qrCodeValue);
|
||||
app.globalData.spread = mapeMpQrCodeValue.spread;
|
||||
this.id = mapeMpQrCodeValue.id;
|
||||
setTimeout(()=>{
|
||||
spread(mapeMpQrCodeValue.spread).then(res => {}).catch(res => {})
|
||||
},2000)
|
||||
|
||||
} else {
|
||||
this.id = options.id;
|
||||
}
|
||||
options.type == undefined || options.type == null ? that.type = 'normal' : that.type = options.type;
|
||||
that.$store.commit("PRODUCT_TYPE", that.type);
|
||||
}
|
||||
uni.getSystemInfo({
|
||||
success: function(res) {
|
||||
that.height = res.windowHeight
|
||||
//res.windowHeight:获取整个窗口高度为px,*2为rpx;98为头部占据的高度;
|
||||
},
|
||||
});
|
||||
//扫码携带参数处理
|
||||
// #ifdef MP
|
||||
if (!options.scene && options.id == 'undefined') return this.$util.Tips({
|
||||
title: '缺少参数无法查看商品'
|
||||
}, {
|
||||
tab: 3,
|
||||
url: 1
|
||||
});
|
||||
options.scene ? this.id = app.globalData.id : this.id = options.id;
|
||||
// #endif
|
||||
this.getGoodsDetails();
|
||||
this.getCouponList();
|
||||
this.isLogin && silenceBindingSpread();
|
||||
this.getProductReplyList();
|
||||
this.getProductReplyCount();
|
||||
this.getGoods();
|
||||
|
|
|
@ -6,29 +6,30 @@
|
|||
<view class='item acea-row row-between-wrapper' style="border: none;">
|
||||
<view class='name'>姓名</view>
|
||||
<input type='text' placeholder='请输入姓名' placeholder-style="color:#ccc;" name='realName' :value="userAddress.realName"
|
||||
placeholder-class='placeholder'></input>
|
||||
placeholder-class='placeholder' maxlength="4"></input>
|
||||
</view>
|
||||
<view class='item acea-row row-between-wrapper'>
|
||||
<view class='name'>联系电话</view>
|
||||
<input type='text' placeholder='请输入联系电话' placeholder-style="color:#ccc;" name="phone" :value='userAddress.phone'
|
||||
placeholder-class='placeholder'></input>
|
||||
<input type='number' placeholder='请输入联系电话' placeholder-style="color:#ccc;" name="phone" :value='userAddress.phone'
|
||||
placeholder-class='placeholder' maxlength="11"></input>
|
||||
</view>
|
||||
<view class='item acea-row row-between-wrapper'>
|
||||
<view class='item acea-row row-between-wrapper relative'>
|
||||
<view class='name'>所在地区</view>
|
||||
<view class="address">
|
||||
<picker mode="multiSelector" @change="bindRegionChange"
|
||||
@columnchange="bindMultiPickerColumnChange" :value="valueRegion" :range="multiArray">
|
||||
<view class='acea-row'>
|
||||
<view class="picker line1">{{region[0]}},{{region[1]}},{{region[2]}}</view>
|
||||
<view class='iconfont icon-dizhi font-color'></view>
|
||||
<view class='iconfont icon-xiangyou abs_right'></view>
|
||||
</view>
|
||||
</picker>
|
||||
</view>
|
||||
</view>
|
||||
<view class='item acea-row row-between-wrapper'>
|
||||
<view class='item acea-row row-between-wrapper relative'>
|
||||
<view class='name'>详细地址</view>
|
||||
<input type='text' placeholder='请填写具体地址' placeholder-style="color:#ccc;" name='detail' placeholder-class='placeholder'
|
||||
:value='userAddress.detail'></input>
|
||||
v-model='userAddress.detail' maxlength="18"></input>
|
||||
<view class='iconfont icon-dizhi font-color abs_right' @tap="chooseLocation"></view>
|
||||
</view>
|
||||
</view>
|
||||
<view class='default acea-row row-middle borRadius14'>
|
||||
|
@ -49,7 +50,7 @@
|
|||
<!-- #ifdef MP -->
|
||||
<!-- <authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize> -->
|
||||
<!-- #endif -->
|
||||
<home></home>
|
||||
<!-- <home></home> -->
|
||||
</view>
|
||||
</template>
|
||||
|
||||
|
@ -67,12 +68,12 @@
|
|||
import {
|
||||
mapGetters
|
||||
} from "vuex";
|
||||
import wPicker from "@/components/wPicker/w-picker.vue";
|
||||
// #ifdef MP
|
||||
import authorize from '@/components/Authorize';
|
||||
// #endif
|
||||
import home from '@/components/home';
|
||||
// import city from '@/utils/cityData';
|
||||
let app = getApp();
|
||||
export default {
|
||||
components: {
|
||||
// #ifdef MP
|
||||
|
@ -102,7 +103,7 @@
|
|||
defaultRegionCode: '440113',
|
||||
bargain: false, //是否是砍价
|
||||
combination: false, //是否是拼团
|
||||
secKill: false //是否是秒杀
|
||||
secKill: false, //是否是秒杀
|
||||
};
|
||||
},
|
||||
computed: mapGetters(['isLogin']),
|
||||
|
@ -120,39 +121,42 @@
|
|||
onLoad(options) {
|
||||
if (this.isLogin) {
|
||||
this.preOrderNo = options.preOrderNo || 0;
|
||||
// this.cartId = options.cartId || '';
|
||||
// this.pinkId = options.pinkId || 0;
|
||||
// this.couponId = options.couponId || 0;
|
||||
this.id = options.id || 0;
|
||||
// this.secKill = options.secKill || false;
|
||||
// this.combination = options.combination || false;
|
||||
// this.bargain = options.bargain || false;
|
||||
uni.setNavigationBarTitle({
|
||||
title: options.id ? '修改地址' : '添加地址'
|
||||
})
|
||||
this.getUserAddress();
|
||||
this.getCityList();
|
||||
// if(this.district && this.district.length){
|
||||
// this.initialize();
|
||||
// }
|
||||
if(this.$Cache.has('cityList')){
|
||||
//检测城市数据是否存在缓存,有的话从缓存取,没有的话请求接口
|
||||
this.district = this.$Cache.getItem('cityList')
|
||||
this.initialize();
|
||||
}else{
|
||||
this.getCityList();
|
||||
}
|
||||
} else {
|
||||
toLogin();
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
// 回去地址数据
|
||||
// #ifdef APP-PLUS
|
||||
// 获取选择的地区
|
||||
handleGetRegion(region) {
|
||||
this.region = region
|
||||
},
|
||||
// #endif
|
||||
// 获取地址数据
|
||||
getCityList: function() {
|
||||
let that = this;
|
||||
getCity().then(res => {
|
||||
this.district = res.data
|
||||
this.district = res.data;
|
||||
let oneDay = 24 * 3600 * 1000;
|
||||
// this.$Cache.set('cityList', JSON.stringify(res.data)); //设置不过期时间的方法
|
||||
this.$Cache.setItem({name:'cityList',value:res.data,expires:oneDay * 7}); //设置七天过期时间
|
||||
that.initialize();
|
||||
})
|
||||
},
|
||||
initialize: function() {
|
||||
let that = this,
|
||||
province = [],
|
||||
city = [],
|
||||
area = [];
|
||||
let that = this,province = [],city = [],area = [];
|
||||
if (that.district.length) {
|
||||
let cityChildren = that.district[0].child || [];
|
||||
let areaChildren = cityChildren.length ? (cityChildren[0].child || []) : [];
|
||||
|
@ -216,7 +220,7 @@
|
|||
|
||||
break;
|
||||
}
|
||||
// #ifdef MP
|
||||
// #ifdef MP || APP-PLUS
|
||||
this.$set(this.multiArray, 0, multiArray[0]);
|
||||
this.$set(this.multiArray, 1, multiArray[1]);
|
||||
this.$set(this.multiArray, 2, multiArray[2]);
|
||||
|
@ -224,9 +228,6 @@
|
|||
// #ifdef H5
|
||||
this.multiArray = multiArray;
|
||||
// #endif
|
||||
|
||||
|
||||
|
||||
this.multiIndex = multiIndex
|
||||
// this.setData({ multiArray: multiArray, multiIndex: multiIndex});
|
||||
},
|
||||
|
@ -254,6 +255,13 @@
|
|||
that.city_id = res.data.cityId
|
||||
});
|
||||
},
|
||||
chooseLocation: function () {
|
||||
uni.chooseLocation({
|
||||
success: (res) => {
|
||||
this.$set(this.userAddress,'detail',res.address.replace(/.+?(省|市|自治区|自治州|县|区)/g,''));
|
||||
}
|
||||
})
|
||||
},
|
||||
// 导入共享地址(小程序)
|
||||
getWxAddress: function() {
|
||||
let that = this;
|
||||
|
@ -456,9 +464,7 @@
|
|||
setTimeout(function() {
|
||||
if (that.preOrderNo>0) {
|
||||
uni.redirectTo({
|
||||
url: '/pages/users/order_confirm/index?preOrderNo=' + that
|
||||
.preOrderNo + '&addressId=' + (that.id ? that.id : res.data
|
||||
.id)
|
||||
url: '/pages/users/order_confirm/index?preOrderNo=' + that.preOrderNo + '&addressId=' + (that.id ? that.id : res.data.id)
|
||||
})
|
||||
} else {
|
||||
// #ifdef H5
|
||||
|
@ -469,29 +475,7 @@
|
|||
delta: 1,
|
||||
})
|
||||
// #endif
|
||||
|
||||
}
|
||||
|
||||
// if (that.cartId) {
|
||||
// let cartId = that.cartId;
|
||||
// let pinkId = that.pinkId;
|
||||
// let couponId = that.couponId;
|
||||
// that.cartId = '';
|
||||
// that.pinkId = '';
|
||||
// that.couponId = '';
|
||||
// uni.navigateTo({
|
||||
// url: '/pages/users/order_confirm/index?cartId=' + cartId + '&addressId=' + (that.id ? that.id : res.data.id) +'&pinkId=' + pinkId + '&couponId=' + couponId + '&secKill=' + that.secKill + '&combination=' + that.combination + '&bargain=' + that.bargain
|
||||
// });
|
||||
// } else {
|
||||
// // #ifdef H5
|
||||
// return history.back();
|
||||
// // #endif
|
||||
// // #ifndef H5
|
||||
// return uni.navigateBack({
|
||||
// delta: 1,
|
||||
// })
|
||||
// // #endif
|
||||
// }
|
||||
}, 1000);
|
||||
}).catch(err => {
|
||||
return that.$util.Tips({
|
||||
|
@ -510,7 +494,6 @@
|
|||
.addAddress {
|
||||
padding-top: 20rpx;
|
||||
}
|
||||
|
||||
.addAddress .list {
|
||||
background-color: #fff;
|
||||
padding: 0 24rpx;
|
||||
|
@ -548,10 +531,6 @@
|
|||
font-size: 30rpx;
|
||||
}
|
||||
|
||||
.addAddress .list .item picker .iconfont {
|
||||
font-size: 43rpx;
|
||||
}
|
||||
|
||||
.addAddress .default {
|
||||
padding: 0 30rpx;
|
||||
height: 90rpx;
|
||||
|
@ -585,4 +564,15 @@
|
|||
color: #E93323 ;
|
||||
border: 1px solid #E93323;
|
||||
}
|
||||
.relative{
|
||||
position: relative;
|
||||
}
|
||||
.icon-dizhi{
|
||||
font-size: 44rpx;
|
||||
z-index: 100;
|
||||
}
|
||||
.abs_right{
|
||||
position: absolute;
|
||||
right:0;
|
||||
}
|
||||
</style>
|
||||
|
|
|
@ -18,7 +18,8 @@
|
|||
width: 375px;
|
||||
height: 667px;
|
||||
background-color: #fff;
|
||||
box-sizing: content-box;
|
||||
/* box-sizing: content-box; */
|
||||
box-sizing: border-box;
|
||||
border: none;
|
||||
}
|
||||
|
||||
|
@ -39,20 +40,15 @@
|
|||
window.isPC = true;
|
||||
window.onload = function(){
|
||||
/* 监听电脑浏览器窗口尺寸改变 */
|
||||
window.onresize = function(){
|
||||
/* 窗口宽度 小于或等于420px 时,跳转回H5页面 */
|
||||
if(window.innerWidth <= 420){
|
||||
// window.location.pathname = 'https://java.crmeb.net/';
|
||||
/* 若你的项目未设置根目录(默认为 / 时),则使用下方代码 */
|
||||
window.location.pathname = '';
|
||||
}
|
||||
}
|
||||
if(window.innerWidth <= 420){
|
||||
window.location.pathname = '/';
|
||||
}
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<!-- <iframe src="https://java.crmeb.net/"></iframe> -->
|
||||
<!--若你的项目未设置根目录(默认为 / 时),则使用下方代码-->
|
||||
<iframe src="/"></iframe>
|
||||
<iframe src="/" id="iframe"></iframe>
|
||||
</body>
|
||||
</html>
|
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 1.9 KiB |
Before Width: | Height: | Size: 2.4 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 1.5 KiB |
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 2.1 KiB |
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 1.9 KiB |
Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.4 KiB |
Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.0 KiB |
113
utils/cache.js
|
@ -1,3 +1,13 @@
|
|||
// +----------------------------------------------------------------------
|
||||
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2016~2021 https://www.crmeb.com All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: CRMEB Team <admin@crmeb.com>
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
import { EXPIRE } from '../config/app';
|
||||
|
||||
class Cache {
|
||||
|
@ -7,6 +17,7 @@ class Cache {
|
|||
this.cacheGetHandler = uni.getStorageSync;
|
||||
this.cacheClearHandler = uni.removeStorageSync;
|
||||
this.cacheExpire = '_expire_2019_12_17_18_44';
|
||||
this.name = 'storage';
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -18,7 +29,7 @@ class Cache {
|
|||
}
|
||||
|
||||
/**
|
||||
* 字符串转时间戳
|
||||
* 日期字符串转时间戳
|
||||
* @param {Object} expiresTime
|
||||
*/
|
||||
strTotime(expiresTime){
|
||||
|
@ -27,17 +38,64 @@ class Cache {
|
|||
return Math.round(new Date(expires_time).getTime() / 1000);
|
||||
}
|
||||
|
||||
setExpireCaheTag(key, expire) {
|
||||
expire = expire !== undefined ? expire : EXPIRE;
|
||||
if (typeof expire === 'number') {
|
||||
let tag = this.cacheGetHandler(this.cacheExpire), newTag = [],newKeys = [];
|
||||
if (typeof tag === 'object' && tag.length) {
|
||||
newTag = tag.map(item => {
|
||||
newKeys.push(item.key);
|
||||
if (item.key === key) {
|
||||
item.expire = expire === 0 ? 0 : this.time() + expire;
|
||||
}
|
||||
return item;
|
||||
});
|
||||
}
|
||||
if (!newKeys.length || newKeys.indexOf(key) === -1) {
|
||||
newTag.push({
|
||||
key: key,
|
||||
expire: expire === 0 ? 0 : this.time() + expire
|
||||
});
|
||||
}
|
||||
this.cacheSetHandler(this.cacheExpire, newTag);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置过期时间缓存
|
||||
* @param {Object} key
|
||||
* @param {Object} expire
|
||||
* @param {Object} name key
|
||||
* @param {Object} value value
|
||||
* @param {Object} expire 过期时间
|
||||
* @param {Object} startTime 记录何时将值存入缓存,毫秒级
|
||||
*/
|
||||
setExpireCahe(key,expire)
|
||||
{
|
||||
expire = expire !== undefined ? expire : EXPIRE;
|
||||
if (expire) {
|
||||
this.cacheSetHandler(key + this.cacheExpire,this.time() + expire)
|
||||
}
|
||||
setItem(params){
|
||||
let obj = {
|
||||
name:'',
|
||||
value:'',
|
||||
expires:"",
|
||||
startTime:new Date().getTime()
|
||||
}
|
||||
let options = {};
|
||||
//将obj和传进来的params合并
|
||||
Object.assign(options,obj,params);
|
||||
if(options.expires){
|
||||
//如果options.expires设置了的话
|
||||
//以options.name为key,options为值放进去
|
||||
// localStorage.setItem(options.name,JSON.stringify(options));
|
||||
uni.setStorageSync(options.name,JSON.stringify(options));
|
||||
}else{
|
||||
//如果options.expires没有设置,就判断一下value的类型
|
||||
let type = Object.prototype.toString.call(options.value);
|
||||
//如果value是对象或者数组对象的类型,就先用JSON.stringify转一下,再存进去
|
||||
if(Object.prototype.toString.call(options.value) == '[object Object]'){
|
||||
options.value = JSON.stringify(options.value);
|
||||
}
|
||||
if(Object.prototype.toString.call(options.value) == '[object Array]'){
|
||||
options.value = JSON.stringify(options.value);
|
||||
}
|
||||
// localStorage.setItem(options.name,options.value);
|
||||
uni.setStorageSync(options.name,options.value);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -76,8 +134,8 @@ class Cache {
|
|||
if(typeof data === 'object')
|
||||
data = JSON.stringify(data);
|
||||
try{
|
||||
this.setExpireCahe(key,expire);
|
||||
return this.cacheSetHandler(key,data);
|
||||
this.setExpireCaheTag(key,expire);
|
||||
return this.cacheSetHandler(key,data);
|
||||
}catch(e){
|
||||
return false;
|
||||
}
|
||||
|
@ -150,6 +208,39 @@ class Cache {
|
|||
// })
|
||||
// }
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取缓存,调用后无需转换数据类型
|
||||
* @param {Object} key
|
||||
*/
|
||||
getItem(name){
|
||||
// let item = localStorage.getItem(name);
|
||||
let item = uni.getStorageSync(name);
|
||||
//先将拿到的试着进行json转为对象的形式
|
||||
try{
|
||||
item = JSON.parse(item);
|
||||
}catch(error){
|
||||
//如果不行就不是json的字符串,就直接返回
|
||||
item = item;
|
||||
}
|
||||
//如果有startTime的值,说明设置了失效时间
|
||||
if(item.startTime){
|
||||
let date = new Date().getTime();
|
||||
//何时将值取出减去刚存入的时间,与item.expires比较,如果大于就是过期了,如果小于或等于就还没过期
|
||||
if(date - item.startTime > item.expires){
|
||||
//缓存过期,清除缓存,返回false
|
||||
// localStorage.removeItem(name);
|
||||
uni.removeStorageSync(name);
|
||||
return false;
|
||||
}else{
|
||||
//缓存未过期,返回值
|
||||
return item.value;
|
||||
}
|
||||
}else{
|
||||
//如果没有设置失效时间,直接返回值
|
||||
return item;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -533,6 +533,30 @@ export default {
|
|||
}
|
||||
return value;
|
||||
},
|
||||
/**根据格式组装公共参数
|
||||
* @param {Object} value
|
||||
*/
|
||||
formatMpQrCodeData(value){
|
||||
let values = value.split(',');
|
||||
let result = {};
|
||||
if(values.length === 2){
|
||||
let v1 = values[0].split(":");
|
||||
if (v1[0] === 'pid') {
|
||||
result.spread = v1[1];
|
||||
} else{
|
||||
result.id = v1[1];
|
||||
}
|
||||
let v2 = values[1].split(":");
|
||||
if (v2[0] === 'pid') {
|
||||
result.spread = v2[1];
|
||||
}else{
|
||||
result.id = v2[1];
|
||||
}
|
||||
}else{
|
||||
result = values[0].split(":")[1];
|
||||
}
|
||||
return result;
|
||||
},
|
||||
// #endif
|
||||
/*
|
||||
* 合并数组
|
||||
|
|