detail.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659
  1. <template>
  2. <view class="content">
  3. <u-navbar title=" " @leftClick="leftClick" height="44px" bgColor="#F5F5F5" :placeholder="true">
  4. <view class="hflex acenter" slot="center">
  5. <view class="nav_item" @click="changeNav(1)" :class="nav_active == 1?'nav_active': '' ">商品</view>
  6. <view class="nav_item" @click="changeNav(2)" :class="nav_active == 2?'nav_active': '' ">详情</view>
  7. </view>
  8. </u-navbar>
  9. <view class="swiper">
  10. <u-swiper :list="pageData.imgList" height="300" @change="e => currentNum = e.current" :autoplay="false" indicatorStyle="right: 20px">
  11. <view slot="indicator" class="indicator-num">
  12. <text class="indicator-num__text">{{ currentNum + 1 }}/{{ pageData.imgList.length }}</text>
  13. </view>
  14. </u-swiper>
  15. </view>
  16. <view class="box">
  17. <view class="hflex acenter jbetween">
  18. <view class="price">¥{{pageData.price}}</view>
  19. <view class="hflex acenter">
  20. <view class="vflex acenter" @click="collect">
  21. <u-icon name="star" color="#444444" size="20" v-if="pageData.is_collect == 0"></u-icon>
  22. <u-icon name="star-fill" color="#506DFF" size="20" v-else></u-icon>
  23. <view class="text_style1">收藏</view>
  24. </view>
  25. <view class="vflex acenter" style="margin-left: 42rpx;">
  26. <image src="/static/images/comment/share.png" class="bottom_img"></image>
  27. <view class="text_style1">分享</view>
  28. </view>
  29. </view>
  30. </view>
  31. <view class="name">{{pageData.name}}</view>
  32. </view>
  33. <view class="box">
  34. <view class="hflex acenter jbetween" @click="openNorm">
  35. <view class="hflex acenter">
  36. <view class="label">选择</view>
  37. <view class="text_style2">{{normStr?normStr:'选择规格'}}</view>
  38. </view>
  39. <u-icon name="arrow-right" color="#000" size="14"></u-icon>
  40. </view>
  41. <view class="hflex acenter jbetween pad-20" @click="openAddr">
  42. <view class="hflex acenter">
  43. <view class="label">配送</view>
  44. <view class="text_style2">{{delivery?delivery:'选择配送地址'}}</view>
  45. </view>
  46. <u-icon name="arrow-right" color="#000" size="14"></u-icon>
  47. </view>
  48. </view>
  49. <view class="box1">
  50. <view class="title">商品图文详情</view>
  51. <block v-for="(item,index) in pageData.detail" :key="index">
  52. <image :src="item" mode="widthFix" class="detail_img"></image>
  53. </block>
  54. </view>
  55. <view class="bottom hflex acenter jbetween">
  56. <view class="vflex acenter" @click="toShop">
  57. <image src="/static/images/shop/shop_icon.png" class="bottom_img"></image>
  58. <view class="text_style1">店铺</view>
  59. </view>
  60. <view class="vflex acenter">
  61. <image src="/static/images/shop/customer_icon.png" class="bottom_img"></image>
  62. <view class="text_style1">客服</view>
  63. </view>
  64. <view class="vflex acenter" @click="toCart">
  65. <image src="/static/images/shop/cart_icon.png" class="bottom_img"></image>
  66. <view class="text_style1">购物车</view>
  67. </view>
  68. <view class="hflex acenter">
  69. <view class="btn1" @click="addCart">加入购物车</view>
  70. <view class="btn2" @click="buy">立即购买</view>
  71. </view>
  72. </view>
  73. <u-popup :show="norm_show" @close="close" mode="bottom" :round="20" :closeable="true">
  74. <view class="popu">
  75. <view class="hflex acenter">
  76. <image :src="pageData.imgList[0]" class="popu_img" mode="aspectFill"></image>
  77. <view class="vflex jbetween popu_right">
  78. <view class="popu_price">¥{{pageData.price}}</view>
  79. <view class="popu_norm">{{normStr?normStr:'选择规格'}}</view>
  80. </view>
  81. </view>
  82. <view class="popu_title">规格</view>
  83. <view class="hflex acenter fwrap">
  84. <block v-for="(item,index) in pageData.norm.normList" :key="index">
  85. <view class="popu_box" @click="selectNorm(item.index)" :class="norm_active == item.index?'sele_active':''">{{item.name}}</view>
  86. </block>
  87. </view>
  88. <view class="popu_title">颜色</view>
  89. <view class="hflex acenter fwrap">
  90. <block v-for="(item,index) in pageData.norm.colorList" :key="index">
  91. <view class="popu_box" @click="selectColor(item.index)" :class="color_active == item.index?'sele_active':''">{{item.name}}</view>
  92. </block>
  93. </view>
  94. <view class="hflex acenter jbetween">
  95. <view class="popu_title">数量</view>
  96. <u-number-box v-model="pageData.norm.num" @change="changeNum"></u-number-box>
  97. </view>
  98. <view class="sure_btn" @click="sure">确定</view>
  99. </view>
  100. </u-popup>
  101. <u-popup :show="addr_show" @close="close" mode="bottom" :round="20" :closeable="true">
  102. <view class="popu">
  103. <view class="hflex acenter jcenter popu_title">配送地址</view>
  104. <view>
  105. <block v-for="(item,index) in pageData.delivery" :key="index">
  106. <view class="box_bg hflex acenter" @click="selectAddr(index)">
  107. <image v-if="item.checked == 1" src="/static/images/shop/checked.png" class="check_img"></image>
  108. <u-icon v-else name="map-fill" color="#b2b2b2" size="12"></u-icon>
  109. <view class="popu_right2">
  110. <view class="hflex acenter">
  111. <view class="popu_name">{{item.name}}</view>
  112. <view class="popu_phone">{{item.phone}}</view>
  113. </view>
  114. <view class="popu_addr">{{item.province}} {{item.city}} {{item.area}} {{item.address}}</view>
  115. </view>
  116. </view>
  117. </block>
  118. </view>
  119. <view class="sure_btn" @click="select">选择其他收货地址</view>
  120. </view>
  121. </u-popup>
  122. </view>
  123. </template>
  124. <script>
  125. import $api from '@/static/js/api.js'
  126. var that = ''
  127. export default {
  128. data() {
  129. return {
  130. nav_active: 1,
  131. currentNum: 0,
  132. pageData: {
  133. imgList: [
  134. '/static/images/index/class_img1.png',
  135. '/static/images/index/class_img1.png',
  136. '/static/images/index/class_img1.png',
  137. ],
  138. price: '699.33',
  139. name: 'TCL 电视 55英寸 4K超清护眼防蓝光超薄金属全面屏 远程语音',
  140. norm: {
  141. normList: [
  142. {
  143. index: 0,
  144. name: '3kw单相手启动'
  145. },
  146. {
  147. index: 1,
  148. name: '3kw单相手启动'
  149. },
  150. {
  151. index: 2,
  152. name: '3kw单相手启动'
  153. },
  154. {
  155. index: 3,
  156. name: '3kw单相手启动'
  157. },
  158. {
  159. index: 4,
  160. name: '3kw单相手启动'
  161. },
  162. {
  163. index: 5,
  164. name: '3kw单相手启动'
  165. }
  166. ],
  167. colorList: [
  168. {
  169. index: 0,
  170. name: '褐色'
  171. },
  172. {
  173. index: 1,
  174. name: '白色'
  175. },
  176. {
  177. index: 2,
  178. name: '黑色'
  179. },
  180. {
  181. index: 3,
  182. name: '粉色'
  183. },
  184. {
  185. index: 4,
  186. name: '午夜色'
  187. },
  188. {
  189. index: 5,
  190. name: '红色'
  191. }
  192. ],
  193. num: 1
  194. },
  195. delivery: [
  196. {
  197. index: 0,
  198. name: '张大成',
  199. phone: '198****2345',
  200. address: '河北省 保定市 莲池区 未来石4号楼20221室',
  201. delivery: '河北省 保定市 莲池区',
  202. is_default: 1
  203. },
  204. {
  205. index: 1,
  206. name: '张大成',
  207. phone: '198****2345',
  208. address: '河北省 保定市 莲池区 未来石4号楼20221室',
  209. delivery: '河北省 保定市 莲池区',
  210. is_default: 0
  211. },
  212. {
  213. index: 2,
  214. name: '张大成',
  215. phone: '198****2345',
  216. address: '河北省 保定市 莲池区 未来石4号楼20221室',
  217. delivery: '河北省 保定市 莲池区',
  218. is_default: 0
  219. }
  220. ],
  221. 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',],
  222. is_collect: 0,
  223. },
  224. normStr: '',
  225. norm: '',
  226. color: '',
  227. delivery: '',
  228. norm_show: false,
  229. addr_show: false,
  230. norm_active: -1,
  231. color_active:-1,
  232. is_buy: 0,
  233. }
  234. },
  235. onLoad() {
  236. that = this
  237. that.getAddr()
  238. },
  239. onPageScroll(e) {
  240. if(e.scrollTop < 530) {
  241. that.nav_active = 1
  242. } else {
  243. that.nav_active = 2
  244. }
  245. },
  246. methods: {
  247. getAddr() {
  248. $api.req({
  249. url: '/data/api.User/address_list'
  250. }, function(res) {
  251. if(res.code == 1) {
  252. console.log(res);
  253. that.pageData.delivery = res.data.data
  254. for(var i=0;i<that.pageData.delivery.length;i++) {
  255. if(that.pageData.delivery[i].type == 1) {
  256. that.delivery = that.pageData.delivery[i].province+that.pageData.delivery[i].city+that.pageData.delivery[i].area
  257. that.$set(that.pageData.delivery[i],'checked',true)
  258. } else {
  259. that.$set(that.pageData.delivery[i],'checked',true)
  260. }
  261. }
  262. }
  263. })
  264. },
  265. // 返回
  266. leftClick() {
  267. $api.jump(-1)
  268. },
  269. // 切换导航栏
  270. changeNav(index) {
  271. that.nav_active = index
  272. if(index == 1) {
  273. uni.pageScrollTo({
  274. scrollTop: 0,
  275. duration: 300
  276. });
  277. } else {
  278. uni.pageScrollTo({
  279. scrollTop: 530,
  280. duration: 300
  281. });
  282. }
  283. },
  284. // 收藏
  285. collect() {
  286. if(that.pageData.is_collect == 0) {
  287. that.pageData.is_collect = 1
  288. $api.req({
  289. url: '/data/api.Goods/collection',
  290. data: {
  291. goods_id: '4',
  292. }
  293. }, function(res) {
  294. if(res.code == 1) {
  295. console.log(res);
  296. }
  297. })
  298. // $api.info('收藏成功')
  299. } else {
  300. that.pageData.is_collect = 0
  301. $api.info('取消收藏')
  302. }
  303. },
  304. // 打开规格
  305. openNorm() {
  306. that.norm_show = true
  307. },
  308. // 打开配送
  309. openAddr() {
  310. that.addr_show = true
  311. },
  312. // 选择规格
  313. selectNorm(index) {
  314. that.norm_active = index
  315. that.norm = that.pageData.norm.normList[index].name
  316. that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
  317. },
  318. // 选择颜色
  319. selectColor(index) {
  320. that.color_active = index
  321. that.color = that.pageData.norm.colorList[index].name
  322. that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
  323. },
  324. // 选择数量
  325. changeNum(e) {
  326. that.pageData.norm.num = e.value
  327. that.normStr = that.norm + ' ' + that.color + ' ' + 'X' + that.pageData.norm.num
  328. },
  329. // 选择地址
  330. selectAddr(index) {
  331. for(var i=0;i<that.pageData.delivery.length;i++) {
  332. if(i == index) {
  333. console.log(i);
  334. that.$set(that.pageData.delivery[i],'checked',1)
  335. that.delivery = that.pageData.delivery[i].delivery
  336. } else {
  337. that.$set(that.pageData.delivery[i],'checked',0)
  338. }
  339. }
  340. },
  341. // 加入购物车
  342. addCart() {
  343. if(that.norm == '' && that.color == '') {
  344. that.openNorm()
  345. } else {
  346. $api.info('加入购物车成功')
  347. that.close()
  348. }
  349. },
  350. // 立即购买
  351. buy() {
  352. if(that.norm == '' && that.color == '') {
  353. that.is_buy = 1
  354. that.openNorm()
  355. } else {
  356. $api.jump('/page_shop/pages/good/submit')
  357. that.close()
  358. }
  359. },
  360. // 确定选择规格
  361. sure() {
  362. console.log(that.norm);
  363. console.log(that.color);
  364. if(that.norm == '' || that.color == '') {
  365. $api.info('请选择规格')
  366. return
  367. }
  368. if(that.is_buy == 1) {
  369. that.buy()
  370. } else {
  371. that.addCart()
  372. }
  373. },
  374. // 关闭弹窗
  375. close() {
  376. that.norm_show = false
  377. that.addr_show = false
  378. },
  379. // 选择其他收货地址
  380. select() {
  381. $api.jump('/page_shop/pages/address/list')
  382. that.close()
  383. },
  384. // 店铺
  385. toShop() {
  386. $api.jump('/page_shop/pages/good/shop')
  387. },
  388. // 购物车
  389. toCart() {
  390. $api.jump('/page_shop/pages/mine/cart')
  391. }
  392. },
  393. }
  394. </script>
  395. <style lang="scss" scoped>
  396. .content::v-deep {
  397. background: #F5F5F5;
  398. .nav_item {
  399. font-size: 32rpx;
  400. font-weight: 500;
  401. color: #999999;
  402. line-height: 50rpx;
  403. margin-right: 88rpx;
  404. }
  405. .nav_active {
  406. color: #222222;
  407. position: relative;
  408. }
  409. .nav_active::after {
  410. content: "";
  411. position: absolute;
  412. bottom: -8rpx;
  413. left: 11rpx;
  414. width: 40rpx;
  415. height: 8rpx;
  416. background: #506DFF;
  417. border-radius: 6rpx;
  418. }
  419. .swiper {
  420. width: 100%;
  421. margin: 0 0 10rpx;
  422. .indicator {
  423. @include flex(row);
  424. justify-content: center;
  425. }
  426. .indicator-num {
  427. padding: 4rpx 0;
  428. background-color: rgba(0, 0, 0, 0.6);
  429. border-radius: 20rpx;
  430. width: 72rpx;
  431. @include flex;
  432. justify-content: center;
  433. &__text {
  434. color: #FFFFFF;
  435. font-size: 24rpx;
  436. font-weight: 400;
  437. line-height: 30rpx;
  438. }
  439. }
  440. }
  441. .box {
  442. margin: 10rpx auto;
  443. width: 690rpx;
  444. background: #FFFFFF;
  445. border-radius: 16rpx;
  446. box-sizing: border-box;
  447. padding: 26rpx 20rpx;
  448. .price {
  449. font-size: 32rpx;
  450. font-weight: bold;
  451. color: #FF5959;
  452. line-height: 38rpx;
  453. }
  454. .name {
  455. margin-top: 20rpx;
  456. font-size: 36rpx;
  457. font-weight: 500;
  458. color: #222222;
  459. line-height: 50rpx;
  460. }
  461. .bottom_img {
  462. width: 40rpx;
  463. height: 40rpx;
  464. }
  465. .pad-20 {
  466. padding: 40rpx 0 0;
  467. }
  468. .label {
  469. font-size: 26rpx;
  470. font-weight: 400;
  471. color: #979797;
  472. line-height: 36rpx;
  473. padding-right: 32rpx;
  474. }
  475. .text_style2 {
  476. font-size: 26rpx;
  477. font-weight: 400;
  478. color: #333333;
  479. line-height: 36rpx;
  480. }
  481. }
  482. .box1 {
  483. width: 690rpx;
  484. background: #FFFFFF; border-radius: 16rpx;
  485. margin: 10rpx auto 186rpx;
  486. box-sizing: border-box;
  487. padding: 26rpx 0;
  488. .title {
  489. font-size: 30rpx;
  490. font-weight: 400;
  491. color: #222222;
  492. line-height: 42rpx;
  493. width: 100%;
  494. text-align: center;
  495. padding: 30rpx 0;
  496. }
  497. .detail_img {
  498. width: 100%;
  499. padding-bottom: 20rpx;
  500. }
  501. }
  502. .text_style1 {
  503. font-size: 20rpx;
  504. font-weight: 400;
  505. color: #444444;
  506. margin-top: 6rpx;
  507. }
  508. .bottom {
  509. width: 100%;
  510. z-index: 9;
  511. position: fixed;
  512. bottom: 0;
  513. height: 166rpx;
  514. background: #FFFFFF;
  515. box-sizing: border-box;
  516. padding: 8rpx 30rpx 74rpx;
  517. .btn1 {
  518. width: 220rpx;
  519. height: 72rpx;
  520. background: #FFCA43;
  521. border-radius: 38rpx 0px 0px 38rpx;
  522. font-size: 28rpx;
  523. font-weight: 500;
  524. color: #FFFFFF;
  525. text-align: center;
  526. line-height: 72rpx;
  527. }
  528. .btn2 {
  529. width: 220rpx;
  530. height: 72rpx;
  531. background: #506DFF;
  532. border-radius: 0px 38rpx 38rpx 0px;
  533. font-size: 28rpx;
  534. font-weight: 500;
  535. color: #FFFFFF;
  536. text-align: center;
  537. line-height: 72rpx;
  538. }
  539. .bottom_img {
  540. width: 40rpx;
  541. height: 40rpx;
  542. }
  543. }
  544. .popu {
  545. background: #FFFFFF;
  546. box-sizing: border-box;
  547. padding: 48rpx 30rpx;
  548. .popu_img {
  549. width: 160rpx;
  550. height: 160rpx;
  551. border-radius: 12rpx;
  552. margin-right: 20rpx;
  553. }
  554. .popu_right {
  555. height: 124rpx;
  556. margin: 20rpx 0 16rpx;
  557. .popu_price {
  558. font-size: 28rpx;
  559. font-weight: 400;
  560. color: #FF4747;
  561. line-height: 34rpx;
  562. }
  563. .popu_norm {
  564. font-size: 24rpx;
  565. font-weight: 400;
  566. color: #A7A7A7;
  567. line-height: 34rpx;
  568. }
  569. }
  570. .popu_title {
  571. font-size: 28rpx;
  572. font-weight: 500;
  573. color: #222222;
  574. line-height: 40rpx;
  575. padding: 20rpx 0;
  576. }
  577. .box_bg {
  578. background: #F5F5F5;
  579. border-radius: 16rpx;
  580. box-sizing: border-box;
  581. padding: 24rpx 20rpx;
  582. margin: 10rpx 0;
  583. .check_img {
  584. width: 24rpx;
  585. height: 24rpx;
  586. }
  587. .popu_right2 {
  588. padding-left: 30rpx;
  589. .popu_name {
  590. font-size: 28rpx;
  591. font-weight: 500;
  592. color: #222222;
  593. line-height: 40rpx;
  594. }
  595. .popu_phone {
  596. padding-left: 16rpx;
  597. font-size: 22rpx;
  598. font-weight: 400;
  599. color: #999999;
  600. line-height: 16px;
  601. }
  602. .popu_addr {
  603. padding: 16rpx 0 0;
  604. font-size: 24rpx;
  605. font-weight: 400;
  606. color: #444444;
  607. line-height: 34rpx;
  608. }
  609. }
  610. }
  611. .popu_box {
  612. background: #F4F4F4;
  613. border-radius: 8rpx;
  614. font-size: 26rpx;
  615. font-weight: 400;
  616. color: #222222;
  617. line-height: 36rpx;
  618. padding: 14rpx 36rpx;
  619. margin: 0 22rpx 28rpx 0;
  620. }
  621. // .popu_box:nth-child(4n+4) {
  622. // margin: 0 0 28rpx 0;
  623. // }
  624. .sele_active {
  625. background: #F1F4FF;
  626. border: 1px solid #5471FF;
  627. color: #506DFF;
  628. }
  629. .sure_btn {
  630. width: 100%;
  631. height: 84rpx;
  632. background: #506DFF;
  633. border-radius: 42rpx;
  634. font-size: 36rpx;
  635. font-weight: 500;
  636. color: #FFFFFF;
  637. line-height: 84rpx;
  638. text-align: center;
  639. margin-top: 94rpx;
  640. }
  641. }
  642. }
  643. </style>