|
@@ -7,18 +7,18 @@
|
|
|
</view>
|
|
|
</u-navbar>
|
|
|
<view class="swiper">
|
|
|
- <u-swiper :list="pageData.imgList" height="300" @change="e => currentNum = e.current" :autoplay="false" indicatorStyle="right: 20px">
|
|
|
+ <u-swiper :list="pageData.slider" height="300" @change="e => currentNum = e.current" :autoplay="false" indicatorStyle="right: 20px">
|
|
|
<view slot="indicator" class="indicator-num">
|
|
|
- <text class="indicator-num__text">{{ currentNum + 1 }}/{{ pageData.imgList.length }}</text>
|
|
|
+ <text class="indicator-num__text">{{ currentNum + 1 }}/{{ pageData.slider.length }}</text>
|
|
|
</view>
|
|
|
</u-swiper>
|
|
|
</view>
|
|
|
<view class="box">
|
|
|
<view class="hflex acenter jbetween">
|
|
|
- <view class="price">¥{{pageData.price}}</view>
|
|
|
+ <view class="price">¥{{pageData.price_selling}}</view>
|
|
|
<view class="hflex acenter">
|
|
|
<view class="vflex acenter" @click="collect">
|
|
|
- <u-icon name="star" color="#444444" size="20" v-if="pageData.is_collect == 0"></u-icon>
|
|
|
+ <u-icon name="star" color="#444444" size="20" v-if="pageData.is_collection == 0"></u-icon>
|
|
|
<u-icon name="star-fill" color="#506DFF" size="20" v-else></u-icon>
|
|
|
<view class="text_style1">收藏</view>
|
|
|
</view>
|
|
@@ -48,9 +48,10 @@
|
|
|
</view>
|
|
|
<view class="box1">
|
|
|
<view class="title">商品图文详情</view>
|
|
|
- <block v-for="(item,index) in pageData.detail" :key="index">
|
|
|
+ <!-- <block v-for="(item,index) in pageData.detail" :key="index">
|
|
|
<image :src="item" mode="widthFix" class="detail_img"></image>
|
|
|
- </block>
|
|
|
+ </block> -->
|
|
|
+ <u-parse :content="pageData.content"></u-parse>
|
|
|
</view>
|
|
|
<view class="bottom hflex acenter jbetween">
|
|
|
<view class="vflex acenter" @click="toShop">
|
|
@@ -73,27 +74,27 @@
|
|
|
<u-popup :show="norm_show" @close="close" mode="bottom" :round="20" :closeable="true">
|
|
|
<view class="popu">
|
|
|
<view class="hflex acenter">
|
|
|
- <image :src="pageData.imgList[0]" class="popu_img" mode="aspectFill"></image>
|
|
|
+ <image :src="pageData.cover" class="popu_img" mode="aspectFill"></image>
|
|
|
<view class="vflex jbetween popu_right">
|
|
|
- <view class="popu_price">¥{{pageData.price}}</view>
|
|
|
+ <view class="popu_price">¥{{pageData.price_selling}}</view>
|
|
|
<view class="popu_norm">{{normStr?normStr:'选择规格'}}</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="popu_title">规格</view>
|
|
|
<view class="hflex acenter fwrap">
|
|
|
- <block v-for="(item,index) in pageData.norm.normList" :key="index">
|
|
|
- <view class="popu_box" @click="selectNorm(item.index)" :class="norm_active == item.index?'sele_active':''">{{item.name}}</view>
|
|
|
+ <block v-for="(item,index) in pageData.items" :key="index">
|
|
|
+ <view class="popu_box" @click="selectNorm(index)" :class="norm_active == index?'sele_active':''">{{item.goods_spec}}</view>
|
|
|
</block>
|
|
|
</view>
|
|
|
- <view class="popu_title">颜色</view>
|
|
|
+ <!-- <view class="popu_title">颜色</view>
|
|
|
<view class="hflex acenter fwrap">
|
|
|
<block v-for="(item,index) in pageData.norm.colorList" :key="index">
|
|
|
<view class="popu_box" @click="selectColor(item.index)" :class="color_active == item.index?'sele_active':''">{{item.name}}</view>
|
|
|
</block>
|
|
|
- </view>
|
|
|
+ </view> -->
|
|
|
<view class="hflex acenter jbetween">
|
|
|
<view class="popu_title">数量</view>
|
|
|
- <u-number-box v-model="pageData.norm.num" @change="changeNum"></u-number-box>
|
|
|
+ <u-number-box v-model="pageData.num" @change="changeNum"></u-number-box>
|
|
|
</view>
|
|
|
<view class="sure_btn" @click="sure">确定</view>
|
|
|
</view>
|
|
@@ -102,7 +103,7 @@
|
|
|
<view class="popu">
|
|
|
<view class="hflex acenter jcenter popu_title">配送地址</view>
|
|
|
<view>
|
|
|
- <block v-for="(item,index) in pageData.delivery" :key="index">
|
|
|
+ <block v-for="(item,index) in deliveryList" :key="index">
|
|
|
<view class="box_bg hflex acenter" @click="selectAddr(index)">
|
|
|
<image v-if="item.checked == 1" src="/static/images/shop/checked.png" class="check_img"></image>
|
|
|
<u-icon v-else name="map-fill" color="#b2b2b2" size="12"></u-icon>
|
|
@@ -131,111 +132,28 @@
|
|
|
nav_active: 1,
|
|
|
currentNum: 0,
|
|
|
pageData: {
|
|
|
- imgList: [
|
|
|
- '/static/images/index/class_img1.png',
|
|
|
- '/static/images/index/class_img1.png',
|
|
|
- '/static/images/index/class_img1.png',
|
|
|
- ],
|
|
|
- price: '699.33',
|
|
|
- name: 'TCL 电视 55英寸 4K超清护眼防蓝光超薄金属全面屏 远程语音',
|
|
|
- norm: {
|
|
|
- normList: [
|
|
|
- {
|
|
|
- index: 0,
|
|
|
- name: '3kw单相手启动'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 1,
|
|
|
- name: '3kw单相手启动'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 2,
|
|
|
- name: '3kw单相手启动'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 3,
|
|
|
- name: '3kw单相手启动'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 4,
|
|
|
- name: '3kw单相手启动'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 5,
|
|
|
- name: '3kw单相手启动'
|
|
|
- }
|
|
|
- ],
|
|
|
- colorList: [
|
|
|
- {
|
|
|
- index: 0,
|
|
|
- name: '褐色'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 1,
|
|
|
- name: '白色'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 2,
|
|
|
- name: '黑色'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 3,
|
|
|
- name: '粉色'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 4,
|
|
|
- name: '午夜色'
|
|
|
- },
|
|
|
- {
|
|
|
- index: 5,
|
|
|
- name: '红色'
|
|
|
- }
|
|
|
- ],
|
|
|
- num: 1
|
|
|
- },
|
|
|
- delivery: [
|
|
|
- {
|
|
|
- index: 0,
|
|
|
- name: '张大成',
|
|
|
- phone: '198****2345',
|
|
|
- address: '河北省 保定市 莲池区 未来石4号楼20221室',
|
|
|
- delivery: '河北省 保定市 莲池区',
|
|
|
- is_default: 1
|
|
|
- },
|
|
|
- {
|
|
|
- index: 1,
|
|
|
- name: '张大成',
|
|
|
- phone: '198****2345',
|
|
|
- address: '河北省 保定市 莲池区 未来石4号楼20221室',
|
|
|
- delivery: '河北省 保定市 莲池区',
|
|
|
- is_default: 0
|
|
|
- },
|
|
|
- {
|
|
|
- index: 2,
|
|
|
- name: '张大成',
|
|
|
- phone: '198****2345',
|
|
|
- address: '河北省 保定市 莲池区 未来石4号楼20221室',
|
|
|
- delivery: '河北省 保定市 莲池区',
|
|
|
- is_default: 0
|
|
|
- }
|
|
|
- ],
|
|
|
- detail: ['/static/images/index/class_img1.png','/static/images/index/class_img2.png','/static/images/index/class_img1.png','/static/images/index/class_img2.png',],
|
|
|
- is_collect: 0,
|
|
|
+
|
|
|
},
|
|
|
normStr: '',
|
|
|
norm: '',
|
|
|
color: '',
|
|
|
delivery: '',
|
|
|
+ deliveryList: [],
|
|
|
+ address_active: 0,
|
|
|
norm_show: false,
|
|
|
addr_show: false,
|
|
|
norm_active: -1,
|
|
|
color_active:-1,
|
|
|
is_buy: 0,
|
|
|
+ id: '',
|
|
|
+ order_no: '',
|
|
|
}
|
|
|
},
|
|
|
- onLoad() {
|
|
|
+ onLoad(options) {
|
|
|
that = this
|
|
|
+ that.id = options.id
|
|
|
that.getAddr()
|
|
|
+ that.getData()
|
|
|
|
|
|
},
|
|
|
onPageScroll(e) {
|
|
@@ -246,19 +164,32 @@
|
|
|
}
|
|
|
},
|
|
|
methods: {
|
|
|
+ getData() {
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Goods/Goods_info',
|
|
|
+ data: {
|
|
|
+ goods_id: that.id
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ that.pageData = res.data
|
|
|
+ that.$set(that.pageData,'num',1)
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
getAddr() {
|
|
|
$api.req({
|
|
|
url: '/data/api.User/address_list'
|
|
|
}, function(res) {
|
|
|
if(res.code == 1) {
|
|
|
- console.log(res);
|
|
|
- that.pageData.delivery = res.data.data
|
|
|
- for(var i=0;i<that.pageData.delivery.length;i++) {
|
|
|
- if(that.pageData.delivery[i].type == 1) {
|
|
|
- that.delivery = that.pageData.delivery[i].province+that.pageData.delivery[i].city+that.pageData.delivery[i].area
|
|
|
- that.$set(that.pageData.delivery[i],'checked',true)
|
|
|
+ that.deliveryList = res.data.data
|
|
|
+ for(var i=0;i<that.deliveryList.length;i++) {
|
|
|
+ if(that.deliveryList[i].type == 1) {
|
|
|
+ that.delivery = that.deliveryList[i].province+that.deliveryList[i].city+that.deliveryList[i].area
|
|
|
+ that.$set(that.deliveryList[i],'checked',true)
|
|
|
+ that.address_active = i
|
|
|
} else {
|
|
|
- that.$set(that.pageData.delivery[i],'checked',true)
|
|
|
+ that.$set(that.deliveryList[i],'checked',false)
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -286,22 +217,31 @@
|
|
|
},
|
|
|
// 收藏
|
|
|
collect() {
|
|
|
- if(that.pageData.is_collect == 0) {
|
|
|
- that.pageData.is_collect = 1
|
|
|
+ if(that.pageData.is_collection == 0) {
|
|
|
+ that.pageData.is_collection = 1
|
|
|
$api.req({
|
|
|
url: '/data/api.Goods/collection',
|
|
|
data: {
|
|
|
- goods_id: '4',
|
|
|
+ goods_id: that.pageData.id,
|
|
|
}
|
|
|
}, function(res) {
|
|
|
if(res.code == 1) {
|
|
|
- console.log(res);
|
|
|
+ $api.info(res.info)
|
|
|
}
|
|
|
})
|
|
|
// $api.info('收藏成功')
|
|
|
} else {
|
|
|
- that.pageData.is_collect = 0
|
|
|
- $api.info('取消收藏')
|
|
|
+ that.pageData.is_collection = 0
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Goods/cancel_collection',
|
|
|
+ data: {
|
|
|
+ goods_id: that.pageData.id,
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ $api.info(res.info)
|
|
|
+ }
|
|
|
+ })
|
|
|
}
|
|
|
},
|
|
|
// 打开规格
|
|
@@ -315,8 +255,8 @@
|
|
|
// 选择规格
|
|
|
selectNorm(index) {
|
|
|
that.norm_active = index
|
|
|
- that.norm = that.pageData.norm.normList[index].name
|
|
|
- that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
|
|
|
+ that.normStr = that.pageData.items[index].goods_spec
|
|
|
+ // that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
|
|
|
},
|
|
|
// 选择颜色
|
|
|
selectColor(index) {
|
|
@@ -326,55 +266,115 @@
|
|
|
},
|
|
|
// 选择数量
|
|
|
changeNum(e) {
|
|
|
- that.pageData.norm.num = e.value
|
|
|
- that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
|
|
|
+ that.pageData.num = e.value
|
|
|
+
|
|
|
},
|
|
|
// 选择地址
|
|
|
selectAddr(index) {
|
|
|
- for(var i=0;i<that.pageData.delivery.length;i++) {
|
|
|
+ for(var i=0;i<that.deliveryList.length;i++) {
|
|
|
if(i == index) {
|
|
|
console.log(i);
|
|
|
- that.$set(that.pageData.delivery[i],'checked',1)
|
|
|
- that.delivery = that.pageData.delivery[i].delivery
|
|
|
+ that.$set(that.deliveryList[i],'checked',1)
|
|
|
+ that.address_active = i
|
|
|
+ that.delivery = that.deliveryList[i].province+that.deliveryList[i].city+that.deliveryList[i].area + that.deliveryList[i].address
|
|
|
+ that.close()
|
|
|
} else {
|
|
|
- that.$set(that.pageData.delivery[i],'checked',0)
|
|
|
+ that.$set(that.deliveryList[i],'checked',0)
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
// 加入购物车
|
|
|
addCart() {
|
|
|
if(that.norm == '' && that.color == '') {
|
|
|
+ that.is_buy = 0
|
|
|
that.openNorm()
|
|
|
} else {
|
|
|
- $api.info('加入购物车成功')
|
|
|
- that.close()
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Goods/cart_add',
|
|
|
+ method: 'POST',
|
|
|
+ data: {
|
|
|
+ admin_id: that.pageData.admin_id,
|
|
|
+ goods_id: that.pageData.id,
|
|
|
+ item_id: that.pageData.items[that.norm_active].id,
|
|
|
+ num: that.pageData.num
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ $api.info('加入购物车成功')
|
|
|
+ that.close()
|
|
|
+ }
|
|
|
+ })
|
|
|
+
|
|
|
}
|
|
|
},
|
|
|
// 立即购买
|
|
|
buy() {
|
|
|
|
|
|
- if(that.norm == '' && that.color == '') {
|
|
|
+ if(that.normStr == '') {
|
|
|
that.is_buy = 1
|
|
|
that.openNorm()
|
|
|
} else {
|
|
|
- $api.jump('/page_shop/pages/good/submit')
|
|
|
- that.close()
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Order/order_create',
|
|
|
+ method: 'POST',
|
|
|
+ data: {
|
|
|
+ admin_id: that.pageData.admin_id,
|
|
|
+ item_id: that.pageData.items[that.norm_active].id,
|
|
|
+ num: that.pageData.num,
|
|
|
+ address_id: that.deliveryList[that.address_active].id
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ $api.info(res.info)
|
|
|
+ that.order_no = res.data
|
|
|
+ $api.jump('/page_shop/pages/good/submit?order_no='+that.order_no)
|
|
|
+ that.close()
|
|
|
+ }
|
|
|
+ })
|
|
|
}
|
|
|
},
|
|
|
// 确定选择规格
|
|
|
sure() {
|
|
|
- console.log(that.norm);
|
|
|
- console.log(that.color);
|
|
|
- if(that.norm == '' || that.color == '') {
|
|
|
+ if(that.normStr == '') {
|
|
|
$api.info('请选择规格')
|
|
|
return
|
|
|
}
|
|
|
- if(that.is_buy == 1) {
|
|
|
- that.buy()
|
|
|
+ if(that.is_buy == 0) {
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Goods/cart_add',
|
|
|
+ method: 'POST',
|
|
|
+ data: {
|
|
|
+ admin_id: that.pageData.admin_id,
|
|
|
+ goods_id: that.pageData.id,
|
|
|
+ item_id: that.pageData.items[that.norm_active].id,
|
|
|
+ num: that.pageData.num
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ $api.info('加入购物车成功')
|
|
|
+ that.close()
|
|
|
+ }
|
|
|
+ })
|
|
|
} else {
|
|
|
- that.addCart()
|
|
|
+ $api.req({
|
|
|
+ url: '/data/api.Order/order_create',
|
|
|
+ method: 'POST',
|
|
|
+ data: {
|
|
|
+ admin_id: that.pageData.admin_id,
|
|
|
+ item_id: that.pageData.items[that.norm_active].id,
|
|
|
+ num: that.pageData.num,
|
|
|
+ address_id: that.deliveryList[that.address_active].id
|
|
|
+ }
|
|
|
+ }, function(res) {
|
|
|
+ if(res.code == 1) {
|
|
|
+ $api.info(res.info)
|
|
|
+ that.order_no = res.data
|
|
|
+ $api.jump('/page_shop/pages/good/submit?order_no='+that.order_no)
|
|
|
+ that.close()
|
|
|
+ }
|
|
|
+ })
|
|
|
+
|
|
|
}
|
|
|
-
|
|
|
},
|
|
|
// 关闭弹窗
|
|
|
close() {
|