Kaynağa Gözat

fix: 四大tab也进入进行登录验证,修正创建订单报错问题

undefined
dengxupeng 4 yıl önce
ebeveyn
işleme
14b104a55c
5 değiştirilmiş dosya ile 128 ekleme ve 118 silme
  1. +1
    -0
      addons/unishop/uniapp/uni-shop/main.js
  2. +21
    -19
      addons/unishop/uniapp/uni-shop/pages/category/category.vue
  3. +47
    -41
      addons/unishop/uniapp/uni-shop/pages/index/index.vue
  4. +36
    -36
      addons/unishop/uniapp/uni-shop/pages/order/createOrder.vue
  5. +23
    -22
      addons/unishop/uniapp/uni-shop/pages/user/user.vue

+ 1
- 0
addons/unishop/uniapp/uni-shop/main.js Dosyayı Görüntüle

@@ -171,6 +171,7 @@ const request = async (url, method = 'GET', data = {}, showMsg = true) => {

// 跳转判断是否登录
const navTo = (url, check = true) => {
console.log(1111111111, url)
if (check && !Vue.prototype.$store.state.hasLogin) {
url = '/pages/public/login';
}


+ 21
- 19
addons/unishop/uniapp/uni-shop/pages/category/category.vue Dosyayı Görüntüle

@@ -35,38 +35,40 @@

},
onShareAppMessage(e){
},
onLoad(){
this.loadData();
},
methods: {
async loadData(){
var that = this;
//let list = await this.$api.json('cateList');
let list = await this.$api.request('/category/all');
if (list) {
uni.stopPullDownRefresh();
list.forEach(item=>{
if(item.pid == 0){
if (that.currentId == 0) {
that.currentId = item.id;
let login = await this.$api.checkLogin();
if (login) {
var that = this;
//let list = await this.$api.json('cateList');
let list = await this.$api.request('/category/all');
if (list) {
uni.stopPullDownRefresh();
list.forEach(item=>{
if(item.pid == 0){
if (that.currentId == 0) {
that.currentId = item.id;
}
this.flist.push(item); //pid为父级id, 没有pid或者pid=0是一级分类
}else {
this.slist.push(item); //没有图的是2级分类
}
this.flist.push(item); //pid为父级id, 没有pid或者pid=0是一级分类
}else {
this.slist.push(item); //没有图的是2级分类
}
})
})

}
}
},
//一级分类点击
tabtap(item){
if(!this.sizeCalcState){
this.calcSize();
}
this.currentId = item.id;
let index = this.flist.findIndex(fitem=>fitem.id === item.id);
this.tabScrollTop = this.flist[index].top;
@@ -190,7 +192,7 @@
font-size: 26upx;
color: #666;
padding-bottom: 20upx;
image{
width: 140upx;
height: 140upx;


+ 47
- 41
addons/unishop/uniapp/uni-shop/pages/index/index.vue Dosyayı Görüntüle

@@ -120,7 +120,7 @@
<text class="title clamp">{{ item.title }}</text>
<text class="price">¥{{ item.price }}</text>
</view>
<view class="more">
<view class="more">
<text>查看全部</text>
<text>More+</text>
</view>
@@ -215,7 +215,7 @@ export default {
};
},
computed:{
},
onLoad() {
this.loadData();
@@ -232,52 +232,58 @@ export default {
this.loadData();
},
onShareAppMessage(e) {
},
methods: {
/**
* 请求静态数据只是为了代码不那么乱
* 分次请求未作整合
*/
loadData() {
async loadData() {
let that = this;
//获取广告图
uni.request({
url: that.$unishow + '/ads/index',
success(res) {
let carouselList = res.data.data;
that.titleNViewBackground = carouselList[0].background;
that.swiperLength = carouselList.length;
that.carouselList = carouselList;
}
});
//获取菜单栏
uni.request({
url: that.$unishow + '/category/menu',
success(res) {
that.menu = res.data.data;
}
});
uni.stopPullDownRefresh();
this.getFlash();
this.getProduct();
let login = await this.$api.checkLogin();
if (login) {
//获取广告图
uni.request({
url: that.$unishow + '/ads/index',
success(res) {
let carouselList = res.data.data;
that.titleNViewBackground = carouselList[0].background;
that.swiperLength = carouselList.length;
that.carouselList = carouselList;
}
});

//获取菜单栏
uni.request({
url: that.$unishow + '/category/menu',
success(res) {
that.menu = res.data.data;
}
});

uni.stopPullDownRefresh();

this.getFlash();

this.getProduct();
}

},
// 获取产品列表
async getProduct() {
let goodsList = await this.$api.request('/product/lists', 'GET', {page:this.page, pagesize:this.pageSize});
if (goodsList) {
if (goodsList.length > 0) {
goodsList.forEach(item=>{
this.goodsList.push(item);
});
this.page++;
} else {
this.$api.msg('没有更多数据');
let login = await this.$api.checkLogin();
if (login) {
let goodsList = await this.$api.request('/product/lists', 'GET', {page:this.page, pagesize:this.pageSize});
if (goodsList) {
if (goodsList.length > 0) {
goodsList.forEach(item=>{
this.goodsList.push(item);
});
this.page++;
} else {
this.$api.msg('没有更多数据');
}
}
}
},
@@ -315,10 +321,10 @@ export default {
},
// 跳转页面
navTo(url){
uni.navigateTo({
uni.navigateTo({
url
})
},
})
},
// 跳转到商品列表
navToList(fid) {
uni.navigateTo({


+ 36
- 36
addons/unishop/uniapp/uni-shop/pages/order/createOrder.vue Dosyayı Görüntüle

@@ -17,15 +17,15 @@

<image class="a-bg" src=""></image>
</navigator> -->
<view class="progress" v-if="progress.number">
<!-- <ProgressBar
class="ProgressBar"
:Sold="progress.sold"
<!-- <ProgressBar
class="ProgressBar"
:Sold="progress.sold"
:widthUpx="250"
:Width="percentage(progress.number, progress.sold)"
Type="candy"
:Width="percentage(progress.number, progress.sold)"
Type="candy"
:Vice="true"></ProgressBar> -->
</view>

@@ -173,7 +173,7 @@

if (options.hasOwnProperty('cart')) {
this.cart = options.cart;
// 从购物车进入
// 从购物车进入
this.getOrderCreate({
cart: options.cart
});
@@ -238,7 +238,7 @@
this.couponList = data.coupon;
this.deliveryList = data.delivery;
this.calcTotal();
if (data.flash) {
this.progress = data.flash;
}
@@ -262,7 +262,7 @@
this.payType = type;
},
async submit() {
// // 如果没有地址则提示先加地址
// if (!this.addressData || !this.addressData.hasOwnProperty('city_id')) {
// this.$api.msg('请选择收货地址');
@@ -277,7 +277,7 @@
let coupon_id = 0;
if (this.couponList && this.couponList[this.useCouponIndex] && this.couponList[this.useCouponIndex].id) {
coupon_id = this.couponList[this.useCouponIndex].id;
}
}
let data = {
// city_id: this.addressData.city_id,
// address_id: this.addressData.id,
@@ -305,11 +305,11 @@
let result = await this.$api.request(apiUrl, 'POST', data);
if (result) {
this.submitLock = false; // 解除锁
this.$api.msg('已提交', 2000);
this.$api.msg('已提交', 2000);
uni.redirectTo({
url: `/pages/money/pay?order_id=${result.order_id}&total=${this.total}&out_trade_no=${result.out_trade_no}`
});
}
}
this.submitLock = false; // 解除锁
},
stopPrevent() {},
@@ -364,29 +364,29 @@
// first_fee: "0.00" // 首单价钱
// additional: 1 // 续件数量
// additional_fee: "0" // 续件价钱
let delivery = this.deliveryList[this.deliveryIndex];
if (delivery) {
let deliveryPrice = 0;
if (delivery.hasOwnProperty('id')) {
if (delivery.min > number) {
this.$api.msg('必须至少购买' + delivery.min + '件商品才能使用此配送方式', 6000)
}
// 如何为0就赋值1,不然下面的循环会死循环
delivery.first = delivery.first == 0 ? 1 : delivery.first;
delivery.additional = delivery.additional == 0 ? 1 : delivery.additional;
for (let i = 0; i < number;) {
if (i === 0) {
deliveryPrice = deliveryPrice + parseInt(delivery.first_fee);
i = i + parseInt(delivery.first);
} else {
deliveryPrice = deliveryPrice + parseInt(delivery.additional_fee);
i = i + parseInt(delivery.additional);
}
}
}
this.deliveryPrice = deliveryPrice.toFixed(2);
total = total + deliveryPrice;
}
// let delivery = this.deliveryList[this.deliveryIndex];
// if (delivery) {
// let deliveryPrice = 0;
// if (delivery.hasOwnProperty('id')) {
// if (delivery.min > number) {
// this.$api.msg('必须至少购买' + delivery.min + '件商品才能使用此配送方式', 6000)
// }
// // 如何为0就赋值1,不然下面的循环会死循环
// delivery.first = delivery.first == 0 ? 1 : delivery.first;
// delivery.additional = delivery.additional == 0 ? 1 : delivery.additional;
// for (let i = 0; i < number;) {
// if (i === 0) {
// deliveryPrice = deliveryPrice + parseInt(delivery.first_fee);
// i = i + parseInt(delivery.first);
// } else {
// deliveryPrice = deliveryPrice + parseInt(delivery.additional_fee);
// i = i + parseInt(delivery.additional);
// }
// }
// }
// this.deliveryPrice = deliveryPrice.toFixed(2);
// total = total + deliveryPrice;
// }

this.total = total.toFixed(2);
},


+ 23
- 22
addons/unishop/uniapp/uni-shop/pages/user/user.vue Dosyayı Görüntüle

@@ -1,6 +1,6 @@
<template>
<view class="container">
<template>
<view class="container">
<view class="user-section">
<image class="bg" src="/static/user-bg.jpg"></image>
<view class="user-info-box">
@@ -20,12 +20,12 @@
<text class="yticon icon-iLinkapp-"></text>
会员
</view>
<text class="e-m">uniShop</text>
<text class="e-m">uniShop</text>
<!-- <text class="e-b">开通会员开发无bug 一测就上线</text> -->
</view>
</view>
<view
<view
class="cover-container"
:style="[{
transform: coverTransform,
@@ -36,7 +36,7 @@
@touchend="coverTouchend"
>
<image class="arc" src="/static/arc.png"></image>
<!-- 订单 -->
<view class="order-header">
<view class="title">我的订单</view>
@@ -93,15 +93,15 @@
<list-cell icon="icon-setting" iconColor="#e07472" title="设置" border="" @eventClick="$api.navTo('/pages/set/set')"></list-cell>
</view>
</view>
</view>
</template>
<script>
</view>
</template>
<script>
import listCell from '@/components/mix-list-cell';
import {
mapState
} from 'vuex';
import {
mapState
} from 'vuex';
let startY = 0, moveY = 0, pageAtTop = true;
export default {
components: {
@@ -122,9 +122,10 @@
}
},
onLoad(){
},
onShow() {
this.$api.checkLogin();
if (this.hasLogin) {
this.getOrderNum();
}
@@ -178,7 +179,7 @@
if(moveDistance >= 80 && moveDistance < 100){
moveDistance = 80;
}
if(moveDistance > 0 && moveDistance <= 80){
this.coverTransform = `translateY(${moveDistance}px)`;
}
@@ -204,9 +205,9 @@
};
}
}
}
}
</script>
}
}
</script>
<style lang='scss'>
page{
background: #f5f5f5;
@@ -415,5 +416,5 @@
}
}
}
</style>
</style>

Yükleniyor…
İptal
Kaydet