You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

432 lines
8.7 KiB

<template>
<view>
<!-- 收货地址 -->
<!-- <view class="addr" @tap="selectAddress">
<view class="icon">
<image src="../../static/img/addricon.png" mode=""></image>
</view>
<view class="right">
<view class="tel-name">
<view class="name">
{{recinfo.name}}
</view>
<view class="tel">
{{recinfo.tel}}
</view>
</view>
<view class="addres">
{{recinfo.address}}
{{recinfo.detail}}
</view>
</view>
</view> -->
<!-- 购买商品列表 -->
<view class="buy-list">
<view class="row" v-for="(row,index) in buylist" :key="index">
<view class="goods-info">
<view class="img">
<image :src="row.img"></image>
</view>
<view class="info">
<view class="title">{{row.cpmc}}</view>
<view class="spec">选择{{row.gg}} <text style="color: red;margin-left: 15upx;">单价:{{row.price}}</text></view>
<view class="price-number">
<view class="price">{{row.je|toFixed}}</view>
<view class="number">
数量:{{row.dinghl}}
</view>
</view>
</view>
</view>
</view>
</view>
<!-- 提示-备注 -->
<view class="order">
<view class="row">
<view class="left">
积分 :
</view>
<view class="right">
已扣除{{int}}积分抵扣{{deduction|toFixed}}
</view>
</view>
<view class="row">
<view class="left">
备注 :
</view>
<view class="right">
<input placeholder="选填,备注内容" v-model="note" />
</view>
</view>
</view>
<!-- 明细 -->
<view class="detail">
<view class="row">
<view class="nominal">
商品金额
</view>
<view class="content">
¥{{goodsPrice|toFixed}}
</view>
</view>
<view class="row" v-if="yid">
<view class="nominal">
优惠券
</view>
<view class="content">
<span class="noyhq">{{showyhq}}</span>
</view>
</view>
</view>
<view class="blck">
</view>
<view class="footer">
<view class="settlement">
<view class="sum">合计:<view class="money">¥{{sumPrice|toFixed}}</view></view>
<view class="btn" @tap="toPay">提交订单</view>
</view>
</view>
</view>
</template>
<script>
import {throttle} from '@/common/util';
export default {
data() {
return {
buylist:[], //订单列表
goodsPrice:0.0, //商品合计价格
sumPrice:0.0, //用户付款价格
freight:0.00, //运费
note:'', //备注
int:0, //抵扣积分
deduction:0, //抵扣价格
recinfo:[],
oneprice:0,//单价
cpids:'',
cpnums:'',
dhid:0,
showyhq:'',
yid:0,//优惠券id
};
},
onLoad(option) {
this.dhid=option.dhid;
this.yid=option.yid;
if(option.yhjine>0){
this.showyhq='¥-'+option.yhjine+'';
let t=this;
setTimeout(function(){
t.sumPrice =parseFloat(t.sumPrice-option.yhjine).toFixed(2);
},200)
}else{
this.showyhq='';
}
},
onShow() {
//页面显示时,加载订单信息
uni.getStorage({
key:'buylist',
success: (ret) => {
this.buylist = ret.data;
console.log(this.buylist,'得到列表')
this.goodsPrice=0;
//合计
let len = this.buylist.length;
for(let i=0;i<len;i++){
if(this.buylist[i].dinghl>0){
this.goodsPrice = this.goodsPrice + (this.buylist[i].dinghl*this.buylist[i].price);
this.cpids=this.cpids+','+this.buylist[i].cpid
this.cpnums=this.cpnums+','+this.buylist[i].dinghl
}
}
this.deduction = this.int/100;
this.sumPrice = this.goodsPrice-this.deduction+this.freight;
}
});
uni.getStorage({
key:'userinfo',
success: (e) => {
this.recinfo = e.data;
}
})
this.getbaseinfo('yunf');
},
onHide() {
},
onBackPress() {
//页面后退时候,清除订单信息
this.clearOrder();
},
filters: {
toFixed:function(x) {
return parseFloat(x).toFixed(2);
}
},
methods: {
async getbaseinfo(key){
let getdata= await this.$api.baseinfo({action:'baseinfo',key:key});
if(getdata.data.info!=''){
if(this.goodsPrice<getdata.data.info[0]){
this.freight=getdata.data.info[1];
this.sumPrice = this.goodsPrice-parseFloat(this.deduction)+parseFloat(this.freight);
}
}
},
async postorder(paymentOrder) {
let getuserinfo=uni.getStorageSync('userinfo');
let paymoney=this.freight+this.sumPrice
uni.hideLoading();
uni.redirectTo({
//这里的价格是显示作用,实际支付价格后台计算
url:"/pages/pay/pay?paymoney="+paymoney+'&dhid='+this.dhid
})
},
clearOrder(){
uni.removeStorage({
key: 'buylist',
success: (res)=>{
this.buylist = [];
console.log('remove buylist success');
}
});
},
toPay:throttle(function(){
//商品列表
let paymentOrder = [];
let goodsid=[];
let len = this.buylist.length;
for(let i=0;i<len;i++){
paymentOrder.push(this.buylist[i]);
goodsid.push(this.buylist[i].id);
}
if(paymentOrder.length==0){
uni.showToast({title:'订单信息有误,请重新购买',icon:'none'});
return ;
}
//本地模拟订单提交UI效果
uni.showLoading({
title:'正在提交订单...'
})
//提交订单
this.postorder(paymentOrder)
}),
//选择收货地址
selectAddress(){
let t=this;
uni.setStorage({
key:'address',
data:t.recinfo,
success() {
uni.navigateTo({
url:"../address/edit/edit?type=edit"
})
}
});
}
}
}
</script>
<style lang="scss">
.addr{
width: 86%;
padding: 20upx 3%;
margin: 30upx auto 20upx auto;
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
border-radius: 20upx;
display: flex;
.icon{
width: 80upx;
height: 80upx;
display: flex;
align-items: center;
image{
width: 60upx;
height: 60upx;
}
}
.tel-name{
width: 100%;
display: flex;
font-size: 32upx;
.tel{
margin-left: 40upx;
}
}
.addres{
width: 100%;
font-size: 26upx;
color: #999;
}
}
.buy-list{
width: 86%;
padding: 10upx 3%;
margin: 30upx auto 20upx auto;
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
border-radius: 20upx;
.row{
margin: 30upx 0;
.goods-info{
width: 100%;
display: flex;
.img{
width: 22vw;
height: 22vw;
border-radius: 10upx;
overflow: hidden;
flex-shrink: 0;
margin-right: 10upx;
image{
width: 22vw;
height: 22vw;
}
}
.info{
width: 100%;
height: 22vw;
overflow: hidden;
display: flex;
flex-wrap: wrap;
position: relative;
.title{
width: 100%;
font-size: 28upx;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
// text-align: justify;
overflow: hidden;
}
.spec{
font-size: 22upx;
background-color: #f3f3f3;
color: #a7a7a7;
height: 40upx;
display: flex;
align-items: center;
padding: 0 10upx;
border-radius: 20upx;
margin-bottom: 20vw;
}
.price-number{
position: absolute;
width: 100%;
bottom: 0upx;
display: flex;
justify-content: space-between;
align-items: flex-end;
font-size: 28upx;
height: 40upx;
.price{
color: #f06c7a;
}
.number{
display: flex;
justify-content: center;
align-items: center;
}
}
}
}
}
}
.order{
width: 86%;
padding: 10upx 3%;
margin: 30upx auto 20upx auto;
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
border-radius: 20upx;
.row{
margin: 20upx 0;
height: 40upx;
display: flex;
.left{
font-size: 28upx;
}
.right{
margin-left: 40upx;
font-size: 26upx;
color: #999;
input{
font-size: 26upx;
color: #999;
}
}
}
}
.blck{
width: 100%;
height: 100upx;
}
.footer{
width: 100%;
padding: 0 4%;
background-color: #fbfbfb;
height: 100upx;
display: flex;
justify-content: flex-end;
align-items: center;
font-size: 28upx;
position: fixed;
bottom: 0upx;
z-index: 5;
.settlement{
width: 80%;
display: flex;
justify-content: flex-end;
align-items: center;
.sum{
width: 50%;
font-size: 28upx;
margin-right: 10upx;
display: flex;
justify-content: flex-end;
.money{
font-weight: 600;
}
}
.btn{
padding: 0 30upx;
height: 60upx;
background-color: #f06c7a;
color: #fff;
display: flex;
justify-content: center;
align-items: center;
font-size: 30upx;
border-radius: 40upx;
}
}
}
.detail{
width: 86%;
padding: 10upx 3%;
margin: 30upx auto 20upx auto;
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
border-radius: 20upx;
.row{
height: 60upx;
display: flex;
justify-content: space-between;
align-items: center;
.nominal{
font-size: 28upx;
}
.content{
font-size: 26upx;
color: #f06c7a;
}
}
}
</style>