Browse Source

修改个人中心,购物车空白区域的问题

zyh
Gao xiaosong 4 years ago
parent
commit
1afb0ce5f8
  1. 2
      config/index.js
  2. 3
      pages/home/index.vue
  3. 141
      pages/shop/ShoppingCart/index.vue
  4. 4
      pages/user/User/index.vue
  5. 6
      剩余问题.js

2
config/index.js

@ -2,6 +2,6 @@
// export const VUE_APP_API_URL = 'http://natapp.xinxintuan.co/api';
// export const VUE_APP_API_URL = 'https://wxapi.yixiang.co/api';
// export const VUE_APP_API_URL = 'http://192.168.31.223:8008/api';
export const VUE_APP_API_URL = 'http://h5api.xinxintuan.co/api';
export const VUE_APP_API_URL = 'https://h5api.xinxintuan.co/api';
export const VUE_APP_RESOURCES_URL = 'https://wx.yixiang.co/static';

3
pages/home/index.vue

@ -21,9 +21,6 @@
<view class="qr" @click="startQr()">
<image src="@/static/images/qr.png" />
</view>
<view class="qr" @click="$yrouter.push({path:'/pages/shop/GoodsEvaluate/index'})">
<image src="@/static/images/qr.png" />
</view>
</view>
<Banner :banner="banner" @getbgcolor="getbgcolor"></Banner>
<uni-notice-bar scrollable="true" @click="goRoll(singNew)" single="true" :speed="10" showIcon="true"

141
pages/shop/ShoppingCart/index.vue

@ -17,19 +17,13 @@
购物数量
<text class="num font-color-red">{{ count }}</text>
</view>
<view
v-if="cartList.valid.length > 0"
class="administrate acea-row row-center-wrapper"
@click="manage"
>{{ footerswitch ? '取消' : '管理' }}</view>
<view v-if="cartList.valid.length > 0" class="administrate acea-row row-center-wrapper" @click="manage">
{{ footerswitch ? '取消' : '管理' }}</view>
</view>
<view v-if="validList.length > 0 || cartList.invalid.length > 0">
<view class="list">
<view
class="item acea-row row-between-wrapper"
v-for="(item, cartListValidIndex) in validList"
:key="cartListValidIndex"
>
<view class="item acea-row row-between-wrapper" v-for="(item, cartListValidIndex) in validList"
:key="cartListValidIndex">
<view class="select-btn">
<view class="checkbox-wrapper">
<checkbox-group @change="switchSelect(cartListValidIndex)">
@ -46,31 +40,19 @@
</view>
<view class="text">
<view class="line1">{{ item.productInfo.storeName }}</view>
<view
class="infor line1"
v-if="item.productInfo.attrInfo"
>属性{{ item.productInfo.attrInfo.sku }}</view>
<view class="infor line1" v-if="item.productInfo.attrInfo">属性{{ item.productInfo.attrInfo.sku }}</view>
<view class="money">{{ item.truePrice }}</view>
</view>
<view class="carnum acea-row row-center-wrapper">
<view
class="reduce"
:class="validList[cartListValidIndex].cartNum <= 1 ? 'on' : ''"
@click.prevent="reduce(cartListValidIndex)"
>-</view>
<view class="reduce" :class="validList[cartListValidIndex].cartNum <= 1 ? 'on' : ''"
@click.prevent="reduce(cartListValidIndex)">-</view>
<view class="num">{{ item.cartNum }}</view>
<view
class="plus"
v-if="validList[cartListValidIndex].attrInfo"
<view class="plus" v-if="validList[cartListValidIndex].attrInfo"
:class="validList[cartListValidIndex].cartNum >= validList[cartListValidIndex].attrInfo.stock ? 'on' : ''"
@click.prevent="plus(cartListValidIndex)"
>+</view>
<view
class="plus"
v-else
@click.prevent="plus(cartListValidIndex)">+</view>
<view class="plus" v-else
:class="validList[cartListValidIndex].cartNum >= validList[cartListValidIndex].stock ? 'on' : ''"
@click.prevent="plus(cartListValidIndex)"
>+</view>
@click.prevent="plus(cartListValidIndex)">+</view>
</view>
</view>
</view>
@ -78,25 +60,15 @@
<view class="invalidGoods" v-if="cartList.invalid.length > 0">
<view class="goodsNav acea-row row-between-wrapper">
<view @click="goodsOpen">
<text
class="iconfont"
:class="goodsHidden === true ? 'icon-xiangyou' : 'icon-xiangxia'"
></text>失效商品
<text class="iconfont" :class="goodsHidden === true ? 'icon-xiangyou' : 'icon-xiangxia'"></text>失效商品
</view>
<view class="del" @click="delInvalidGoods">
<text class="iconfont icon-shanchu1"></text>清空
</view>
</view>
<view class="goodsList" :hidden="goodsHidden">
<view
v-for="(item, cartListinvalidIndex) in cartList.invalid"
:key="cartListinvalidIndex"
>
<view
@click="goGoodsCon(item)"
class="item acea-row row-between-wrapper"
v-if="item.productInfo"
>
<view v-for="(item, cartListinvalidIndex) in cartList.invalid" :key="cartListinvalidIndex">
<view @click="goGoodsCon(item)" class="item acea-row row-between-wrapper" v-if="item.productInfo">
<view class="invalid acea-row row-center-wrapper">失效</view>
<view class="pictrue">
<image :src="item.productInfo.attrInfo.image" v-if="item.productInfo.attrInfo" />
@ -104,10 +76,8 @@
</view>
<view class="text acea-row row-column-between">
<view class="line1">{{ item.productInfo.storeName }}</view>
<view
class="infor line1"
v-if="item.productInfo.attrInfo"
>属性{{ item.productInfo.attrInfo.sku }}</view>
<view class="infor line1" v-if="item.productInfo.attrInfo">属性{{ item.productInfo.attrInfo.sku }}
</view>
<view class="acea-row row-between-wrapper">
<view class="end">该商品已下架</view>
</view>
@ -160,34 +130,41 @@
</view>
</view>
</view>
<Authorization v-if="!$store.getters.token" />
<Authorization v-else />
</view>
</template>
<script>
import Recommend from "@/components/Recommend";
import Authorization from "@/pages/authorization/index";
import { mapGetters } from "vuex";
import Recommend from "@/components/Recommend";
import Authorization from "@/pages/authorization/index";
import {
mapGetters
} from "vuex";
import {
import {
getCartList,
postCartDel,
changeCartNum,
getCartCount
} from "@/api/store";
import { postCollectAll } from "@/api/user";
import { mul, add } from "@/utils/bc";
import cookie from "@/utils/store/cookie";
} from "@/api/store";
import {
postCollectAll
} from "@/api/user";
import {
mul,
add
} from "@/utils/bc";
import cookie from "@/utils/store/cookie";
const CHECKED_IDS = "cart_checked";
const CHECKED_IDS = "cart_checked";
export default {
export default {
name: "ShoppingCart",
components: {
Recommend,
Authorization
},
props: {},
data: function() {
data: function () {
return {
cartList: {
invalid: [],
@ -242,7 +219,7 @@ export default {
this.validList = list.valid;
}
},
onShow: function() {
onShow: function () {
if (this.userInfo.uid) {
this.carnum();
this.countMoney();
@ -259,7 +236,7 @@ export default {
}
});
},
getCartList: function() {
getCartList: function () {
let that = this;
getCartList().then(res => {
that.cartList = res.data;
@ -278,12 +255,12 @@ export default {
});
},
//
delgoods: function() {
delgoods: function () {
let that = this,
id = [],
valid = [],
list = that.cartList.valid;
list.forEach(function(val) {
list.forEach(function (val) {
if (val.checked === true) {
id.push(val.id);
}
@ -296,8 +273,8 @@ export default {
});
return;
}
postCartDel(id).then(function() {
list.forEach(function(val, i) {
postCartDel(id).then(function () {
list.forEach(function (val, i) {
if (val.checked === false || val.checked === undefined)
valid.push(list[i]);
});
@ -309,35 +286,35 @@ export default {
});
},
// //
gainCount: function() {
gainCount: function () {
let that = this;
getCartCount().then(res => {
that.count = res.data.count;
});
},
//
delInvalidGoods: function() {
delInvalidGoods: function () {
let that = this,
id = [],
list = that.cartList.invalid;
list.forEach(function(val) {
list.forEach(function (val) {
id.push(val.id);
});
postCartDel(id).then(function() {
postCartDel(id).then(function () {
list.splice(0, list.length);
that.gainCount();
that.getCartList();
});
},
//;
collectAll: function() {
collectAll: function () {
let that = this,
data = {
id: [],
category: ""
},
list = that.cartList.valid;
list.forEach(function(val) {
list.forEach(function (val) {
if (val.checked === true) {
data.id.push(val.product_id);
data.category = val.type;
@ -351,7 +328,7 @@ export default {
});
return;
}
postCollectAll(data).then(function() {
postCollectAll(data).then(function () {
uni.showToast({
title: "收藏成功!",
icon: "none",
@ -360,11 +337,11 @@ export default {
});
},
//
placeOrder: function() {
placeOrder: function () {
let that = this,
list = that.cartList.valid,
id = [];
list.forEach(function(val) {
list.forEach(function (val) {
if (val.checked === true) {
id.push(val.id);
}
@ -384,16 +361,16 @@ export default {
}
});
},
manage: function() {
manage: function () {
let that = this;
that.footerswitch = !that.footerswitch;
},
goodsOpen: function() {
goodsOpen: function () {
let that = this;
that.goodsHidden = !that.goodsHidden;
},
//
plus: function(index) {
plus: function (index) {
let that = this;
let list = that.cartList.valid[index];
list.cartNum++;
@ -411,7 +388,7 @@ export default {
that.syncCartNum(list);
},
//
reduce: function(index) {
reduce: function (index) {
let that = this;
let list = that.cartList.valid[index];
if (list.cartNum <= 1) {
@ -448,7 +425,7 @@ export default {
}
},
//
switchSelect: function(index) {
switchSelect: function (index) {
let that = this,
cart = that.cartList.valid[index],
i = this.checkedIds.indexOf(cart.id);
@ -474,7 +451,7 @@ export default {
that.countMoney();
},
//
allChecked: function(e) {
allChecked: function (e) {
console.log(e);
let that = this;
let selectAllStatus = e.mp.detail.value[0] == "allSelect" ? true : false;
@ -506,7 +483,7 @@ export default {
this.$forceUpdate();
},
//
carnum: function() {
carnum: function () {
let that = this;
var carnum = 0;
var array = that.cartList.valid;
@ -518,7 +495,7 @@ export default {
that.$set(that, "cartCount", carnum);
},
//
countMoney: function() {
countMoney: function () {
let that = this;
let carmoney = 0;
let array = that.cartList.valid;
@ -530,5 +507,5 @@ export default {
that.countmoney = carmoney;
}
}
};
};
</script>

4
pages/user/User/index.vue

@ -133,7 +133,7 @@
:login_type="userInfo.login_type"
></SwitchWindow>-->
</view>
<Authorization v-if="!$store.getters.token" />
<Authorization v-else />
</view>
</template>
<script>
@ -185,7 +185,7 @@
}
});
},
goBindPhone(){
goBindPhone() {
this.$yrouter.push({
path: "/pages/user/BindingPhone/index",
});

6
剩余问题.js

@ -5,7 +5,7 @@
// ? 未测试出该问题
// 页面都多了一个头部
// ~~延后处理
// ~~ 需要打包h5的时候单独修改配置
// 6、评价图片上传不了
// ?接口报错,反馈给老徐了
@ -14,10 +14,10 @@
// ?接口报错,反馈给老徐了
// 12、h5分享关系没形成,看下你那登陆怎么处理的参考下以前的h5
// ~~ 延后处理
// ?前端功能修改完,后台交给老徐了
// 13、海报分享,分享分享调整没问题,因为是首页,但是,商品详情海报,拼团海报,砍价海报路由跳转会有问题
// ?商品拼团海报生成的不是小程序码
// ?前端功能修改完,后台交给老徐了
// 海报相关页面
// components/StorePoster.vue 商品详情
// > 根据用户来源生成二维码

Loading…
Cancel
Save