product-details.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857
  1. <!-- 商品详情 -->
  2. <template>
  3. <view class="wrap">
  4. <HeaderViewBar ref='HeaderViewBar' title='商品详情' :titleOpacity="scrollTop / 100" :opacity="scrollTop / 100"
  5. :hideBack="true" backgroundColor='linear-gradient(180deg, #E63D23, #F58711)'
  6. style="position: fixed; top: 0; z-index: 999999999;">
  7. <view class="header-btn-box" :style="{width: headerContainerWidth + 'px', paddingRight: 36}">
  8. <button type="default" class="back" @tap="back()">
  9. <image src="../../../static/return-2.png" mode="widthFix"></image>
  10. </button>
  11. <view class="header-right-box">
  12. <button type="default">
  13. <image src="../../../static/circle-1.png" mode="widthFix"></image>
  14. </button>
  15. <button type="default">
  16. <image src="../../../static/circle-2.png" mode="widthFix"></image>
  17. </button>
  18. </view>
  19. </view>
  20. </HeaderViewBar>
  21. <view class="swiper-box">
  22. <swiper class="swiper" @change="swiperChange" :circular="true" autoplay="true" interval="3000"
  23. duration="500">
  24. <!-- <swiper-item v-for="(item,index) in swiperList" :key="index">
  25. <view class="swiper-item">
  26. <image :src="item" class="banner-img" mode="aspectFill" />
  27. </view>
  28. </swiper-item> -->
  29. <swiper-item>
  30. <view class="swiper-item">
  31. <image :src="info.cover" class="banner-img" mode="aspectFill" />
  32. </view>
  33. </swiper-item>
  34. </swiper>
  35. <view class="diandian">
  36. <view class="diandiandian" :class="(swiperCurrent == index ? 'diandiandian_active' : '')"
  37. v-for="(item, index) in swiperList">
  38. </view>
  39. </view>
  40. </view>
  41. <view class="spike-module-box">
  42. <image src="../../../static/bg-17.png" class="spike-bg" mode=""></image>
  43. <view class="spike-module-content">
  44. <view class="spike-module-content-left">
  45. 秒杀价:
  46. <view class="spike-price">
  47. ¥39.00
  48. </view>
  49. <text class="del-price-white">¥56.00</text>
  50. </view>
  51. <view class="spike-module-content-right">
  52. <view class="spike-module-content-right-label">距秒杀截止时间</view>
  53. <view class="bottom-label">
  54. <text class="bottom-label-text">14天</text>
  55. <u-count-down :time="30 * 60 * 60 * 1000" format="HH:mm:ss" autoStart millisecond
  56. @change="onChange">
  57. <view class="time">
  58. <view class="time__custom">
  59. <text
  60. class="time__custom__item">{{ timeData.hours>10?timeData.hours:'0'+timeData.hours}}</text>
  61. </view>
  62. <text class="time__doc">:</text>
  63. <view class="time__custom">
  64. <text class="time__custom__item">{{ timeData.minutes }}</text>
  65. </view>
  66. <text class="time__doc">:</text>
  67. <view class="time__custom">
  68. <text class="time__custom__item">{{ timeData.seconds }}</text>
  69. </view>
  70. </view>
  71. </u-count-down>
  72. </view>
  73. </view>
  74. </view>
  75. </view>
  76. <view class="padding-box">
  77. <view class="module">
  78. <view class="price-row">
  79. ¥394.00 <text class="del-price">¥34.00</text>
  80. </view>
  81. <view class="product-name">
  82. {{info.name}}
  83. </view>
  84. <view class="row-between">
  85. <view class="tag">
  86. 1罐50g
  87. </view>
  88. <view class="box">
  89. <image src="../../../static/bg-8.png" class="bg" mode="aspectFill" />
  90. <view class="fan">
  91. </view>
  92. <view class="fan-prirce">
  93. ¥<text>8.00</text>
  94. </view>
  95. </view>
  96. </view>
  97. <view class="type-list">
  98. <view class="type-item">
  99. 菊花决明子茶
  100. </view>
  101. <view class="type-item pink-border">
  102. 藕粉桂花坚果羹
  103. </view>
  104. <view class="type-item">
  105. 黑芝麻羹
  106. </view>
  107. </view>
  108. </view>
  109. <view class="module">
  110. <view class="module-row">
  111. <view class="module-label">
  112. 产品功效
  113. </view>
  114. <view class="module-right-row">
  115. <text class="child">强身益智</text>
  116. <text class="child">健胃润肠</text>
  117. <button type="default" class="module-btn">健胃润肠</button>
  118. </view>
  119. </view>
  120. <view class="module-row">
  121. <view class="module-label">
  122. 适合人群
  123. </view>
  124. <view class="module-right-row">
  125. <text class="child">亚健康</text>
  126. <text class="child">心血管患者</text>
  127. <text class="child">糖尿病患者</text>
  128. <text class="child">体弱多病</text>
  129. <text class="child">消化不良</text>
  130. <text class="child">心血管患者</text>
  131. <text class="child">糖尿病患者</text>
  132. <text class="child">体弱多病</text>
  133. </view>
  134. </view>
  135. <view class="module-row">
  136. <view class="module-label">
  137. 有效搭配
  138. </view>
  139. <view class="module-right-row-between">
  140. <view class="module-right-row-tab">
  141. <view class="tab-child">
  142. 乌鸡
  143. </view>
  144. <view class="tab-child">
  145. 木耳
  146. </view>
  147. <view class="tab-child">
  148. 枸杞
  149. </view>
  150. </view>
  151. <image src="../../../static/back-icon2.png" mode="widthFix" class="back-icon"></image>
  152. </view>
  153. </view>
  154. </view>
  155. <view class="module">
  156. <view class="module-row">
  157. <view class="module-label">
  158. 配送
  159. </view>
  160. <view class="module-right-row">
  161. <view class="msg">
  162. 嘉兴南湖区旭辉广场2号楼
  163. </view>
  164. </view>
  165. </view>
  166. <view class="module-row">
  167. <view class="module-label">
  168. 发货
  169. </view>
  170. <view class="module-right-row">
  171. <view class="msg">
  172. 北京携手熊猫总部
  173. </view>
  174. <text class="express-shipping">快递:免运费</text>
  175. </view>
  176. </view>
  177. <view class="module-row">
  178. <view class="module-label">
  179. 源头
  180. </view>
  181. <view class="module-right-row">
  182. <view class="msg">
  183. 宁夏中宁县
  184. </view>
  185. <button class="border-orange">产品可溯源</button>
  186. </view>
  187. </view>
  188. <view class="module-row">
  189. <view class="module-label">
  190. 时令
  191. </view>
  192. <view class="module-right-row">
  193. <view class="msg">
  194. 6月/7月/8月
  195. </view>
  196. </view>
  197. </view>
  198. <view class="module-row">
  199. <view class="module-label">
  200. 时令
  201. </view>
  202. <view class="module-right-row-between">
  203. <view class="module-right-row-tab">
  204. <text class="assure">产品可溯源</text>
  205. <text class="assure">七天无理由退换</text>
  206. </view>
  207. <image src="../../../static/back-icon2.png" mode="widthFix" class="back-icon"></image>
  208. </view>
  209. </view>
  210. <view class="module-row">
  211. <view class="module-label">
  212. 参数
  213. </view>
  214. <view class="module-right-row-between">
  215. <view class="module-right-row-tab">
  216. <text class="assure">生产日期</text>
  217. <text class="assure">产地</text>
  218. <text class="assure">净含量…</text>
  219. </view>
  220. </view>
  221. </view>
  222. </view>
  223. <view class="comment-module">
  224. <view class="comment-module-label">
  225. 商品评价(600)
  226. </view>
  227. <view class="comment-box">
  228. <view class="comment-tab-list">
  229. <view class="comment-tab-item">
  230. 口味鲜美多汁
  231. </view>
  232. <view class="comment-tab-item">
  233. 很好吃
  234. </view>
  235. <view class="comment-tab-item">
  236. 还会再买
  237. </view>
  238. </view>
  239. <view class="comment-list">
  240. <!-- <view class="comment-item" v-for="(item, index) in 3">
  241. <view class="comment-item-top">
  242. <image src="../../../static/avatar.png" class="avatar" mode="aspectFill"></image>
  243. <view class="comment-item-top-sidebar">
  244. <view class="comment-item-top-column">
  245. <view class="user-name">
  246. 乔治的晚餐
  247. </view>
  248. <view class="stars-wrapper">
  249. <block v-for="(val, index) in 5">
  250. <image class="star-img"
  251. :src="star > index ? '../../../static/star-active.png' : '../../../static/star.png'"
  252. mode="aspectFill"></image>
  253. </block>
  254. </view>
  255. </view>
  256. <text class="time">2020-9-15</text>
  257. </view>
  258. </view>
  259. <view class="comment-item-content">
  260. 香肠精选不同部位的猪肉,按照一定的肥瘦比列进行搭。香肠精选不同部位的猪肉,按照一定的肥瘦比列进行搭。
  261. </view>
  262. </view> -->
  263. <view class="comment-item" v-for="(item, index) in commentList" :key="index">
  264. <view class="comment-item-top">
  265. <image src="../../../static/avatar.png" class="avatar" mode="aspectFill"></image>
  266. <view class="comment-item-top-sidebar">
  267. <view class="comment-item-top-column">
  268. <view class="user-name">
  269. 乔治的晚餐
  270. </view>
  271. <view class="stars-wrapper">
  272. <block v-for="(val, index) in 5">
  273. <image class="star-img"
  274. :src="star > index ? '../../../static/star-active.png' : '../../../static/star.png'"
  275. mode="aspectFill"></image>
  276. </block>
  277. </view>
  278. </view>
  279. <text class="time">2020-9-15</text>
  280. </view>
  281. </view>
  282. <view class="comment-item-content">
  283. 香肠精选不同部位的猪肉,按照一定的肥瘦比列进行搭。香肠精选不同部位的猪肉,按照一定的肥瘦比列进行搭。
  284. </view>
  285. </view>
  286. </view>
  287. <view class="buyers-show-module">
  288. <view class="buyers-show-label">
  289. 买家秀(14)
  290. </view>
  291. <scroll-view scroll-x="true" class="buyers-show-list">
  292. <image src="../../../static/img-4.png" class="buyers-show-img" v-for="(item, index) in 7"
  293. mode="aspectFill"></image>
  294. </scroll-view>
  295. </view>
  296. </view>
  297. </view>
  298. <view class="details-module">
  299. <view class="details-module-label">
  300. 商品详情
  301. </view>
  302. <view class="details-box">
  303. <image src="../../../static/img-4.png" mode="widthFix" class="img"></image>
  304. </view>
  305. </view>
  306. </view>
  307. <view class="footer">
  308. <view class="footer-leftsidebar">
  309. <button type="default" @tap="shoppingCart">
  310. <image src="../../../static/foot-tab2.png" mode="heightFix"></image>
  311. 购物车
  312. <view class="num">
  313. 99
  314. </view>
  315. </button>
  316. <button type="default">
  317. <image src="../../../static/foot-tab1.png" mode="heightFix"></image>
  318. 客服
  319. </button>
  320. <button type="default" @tap="collect">
  321. <image :src="select ? '../../../static/foot-tab3active.png' : '../../../static/foot-tab3.png'"
  322. mode="heightFix"></image>
  323. {{select ? '已收藏' : '收藏'}}
  324. </button>
  325. </view>
  326. <view class="footer-rightsidebar">
  327. <button type="default" class="footer-rightsidebar-btn" @tap="addCartSuccess">
  328. <image src="../../../static/btn-bg1.png" mode=""></image>
  329. <view class="footer-rightsidebar-btn-container">
  330. 加入购物车
  331. </view>
  332. </button>
  333. <button type="default" class="footer-rightsidebar-btn2">
  334. <image src="../../../static/btn-bg2.png" mode=""></image>
  335. <view class="footer-rightsidebar-btn-container2">
  336. 立即购买
  337. </view>
  338. </button>
  339. </view>
  340. </view>
  341. <!-- 保障-弹窗 -->
  342. <view v-show="isShowAssure">
  343. <view class="mask" @tap="closeAssure"></view>
  344. <view class="window-box">
  345. <view class="window-title">保障</view>
  346. <view class="window-top">
  347. <view class="window-row">
  348. <view class="window-label">产品可溯源</view>
  349. </view>
  350. <view class="window-row">
  351. <view class="window-label">七天无理由退换</view>
  352. <view class="window-msg">满足相应条件(吊牌缺失、洗涤后不支持)时,消费者可以申请“七天无理由退换货”</view>
  353. </view>
  354. </view>
  355. <view class="window-bottom">
  356. <button type="default">确定</button>
  357. </view>
  358. </view>
  359. </view>
  360. <!-- 保障-弹窗 -->
  361. <!-- 选择规格-弹窗 -->
  362. <view v-show="isShowSelectSpecification">
  363. <view class="mask" @tap="closeSelectSpecification"></view>
  364. <view class="selectSpecification-box">
  365. <view class="product-module">
  366. <image src="../../../static/img-4.png" class="product-img" mode="aspectFill"></image>
  367. <view class="product-module-sidebar">
  368. <view class="price-row">
  369. ¥394.00
  370. <text class="del-price">¥34.00</text>
  371. </view>
  372. <view class="product-module-title">藕粉桂花坚果藕粉羹营养早代餐 坚果羹营养早餐懒人冲饮食品</view>
  373. </view>
  374. </view>
  375. <view class="delivery-address-box">
  376. <view class="delivery-address-label">配送地址</view>
  377. <view class="location-row">
  378. <image src="../../../static/location-1.png" class="location-icon" mode=""></image>
  379. <view class="row-location-between">
  380. <text class="location-msg">山东省 临沂市 兰山区 柳青街道 </text>
  381. <image src="../../../static/back-icon2.png" class="back-icon" mode="widthFix"></image>
  382. </view>
  383. </view>
  384. </view>
  385. <view class="taste-row">
  386. <view class="taste-label">
  387. 口味
  388. </view>
  389. <view v-for="(item, index) in list" :key="index">
  390. <view :class="'type ' + [id == index ? 'active' : '']" @click="choseItem(index)">
  391. {{ item.name }}
  392. </view>
  393. </view>
  394. </view>
  395. <view class="number-box-between">
  396. <view class="number-label">购买数量<text>(限购10件)库存1899件</text></view>
  397. <view class="calc_box">
  398. <view class="calc_btn">
  399. <image src="../../../static/less.png" mode="widthFix" />
  400. </view>
  401. <input type="number" value="1" class="calc_number" />
  402. <view class="calc_btn">
  403. <image src="../../../static/add.png" mode="widthFix" />
  404. </view>
  405. </view>
  406. </view>
  407. <view class="window-bottom">
  408. <button type="default">确定</button>
  409. </view>
  410. </view>
  411. </view>
  412. <!-- 选择规格-弹窗 -->
  413. <!-- 限源预售-参数-弹窗 -->
  414. <view v-show="isShowParameter">
  415. <view class="mask" @tap="closeParameter"></view>
  416. <view class="window-box">
  417. <view class="window-title">参数</view>
  418. <view class="window-top">
  419. <view class="parameter-row">
  420. <view class="parameter-row-label">品牌</view>
  421. <view class="parameter-row-msg">程老伯</view>
  422. </view>
  423. <view class="parameter-row">
  424. <view class="parameter-row-label">价格</view>
  425. <view class="parameter-row-msg">0-50元</view>
  426. </view>
  427. <view class="parameter-row">
  428. <view class="parameter-row-label">产地</view>
  429. <view class="parameter-row-msg">中国大陆</view>
  430. </view>
  431. <view class="parameter-row">
  432. <view class="parameter-row-label">省份</view>
  433. <view class="parameter-row-msg">山东省</view>
  434. </view>
  435. <view class="parameter-row">
  436. <view class="parameter-row-label">同城服务</view>
  437. <view class="parameter-row-msg">同城24小时物流送货上门</view>
  438. </view>
  439. <view class="parameter-row">
  440. <view class="parameter-row-label">包装方式</view>
  441. <view class="parameter-row-msg">包装</view>
  442. </view>
  443. <view class="parameter-row">
  444. <view class="parameter-row-label">售卖方式</view>
  445. <view class="parameter-row-msg">单品</view>
  446. </view>
  447. <view class="parameter-row">
  448. <view class="parameter-row-label">套餐份量</view>
  449. <view class="parameter-row-msg">5人份</view>
  450. </view>
  451. <view class="parameter-row">
  452. <view class="parameter-row-label">套餐周期</view>
  453. <view class="parameter-row-msg">1周</view>
  454. </view>
  455. <view class="parameter-row">
  456. <view class="parameter-row-label">配送频次</view>
  457. <view class="parameter-row-msg">1周2次</view>
  458. </view>
  459. <view class="parameter-row">
  460. <view class="parameter-row-label">净含量</view>
  461. <view class="parameter-row-msg">500g 1500g 2500g</view>
  462. </view>
  463. <view class="parameter-row">
  464. <view class="parameter-row-label">厂址</view>
  465. <view class="parameter-row-msg">山东烟台</view>
  466. </view>
  467. <view class="parameter-row">
  468. <view class="parameter-row-label">厂家联系方式</view>
  469. <view class="parameter-row-msg">05358585333</view>
  470. </view>
  471. <view class="parameter-row">
  472. <view class="parameter-row-label">厂名</view>
  473. <view class="parameter-row-msg">程老伯旗舰店</view>
  474. </view>
  475. <view class="parameter-row">
  476. <view class="parameter-row-label">保质期</view>
  477. <view class="parameter-row-msg">7</view>
  478. </view>
  479. </view>
  480. <view class="window-bottom">
  481. <button type="default">确定</button>
  482. </view>
  483. </view>
  484. </view>
  485. <!-- 限源预售-参数-弹窗 -->
  486. <!-- 限源预售-选择规格-弹窗 -->
  487. <view v-show="isShowPreSaleSelectSpecification">
  488. <view class="mask" @tap="closePreSaleSelectSpecification"></view>
  489. <view class="selectSpecification-box">
  490. <view class="product-module">
  491. <image src="../../../static/img-4.png" class="product-img" mode="aspectFill"></image>
  492. <view class="product-module-sidebar">
  493. <view class="price-row">
  494. ¥394.00
  495. <text class="del-price">¥34.00</text>
  496. </view>
  497. <view class="product-module-title">陶太萌油蟠桃(黄肉蟠桃)</view>
  498. </view>
  499. </view>
  500. <view class="delivery-address-box">
  501. <view class="delivery-address-label">配送地址</view>
  502. <view class="location-row">
  503. <image src="../../../static/location-1.png" class="location-icon" mode=""></image>
  504. <view class="row-location-between">
  505. <text class="location-msg">山东省 临沂市 兰山区 柳青街道 </text>
  506. <image src="../../../static/back-icon2.png" class="back-icon" mode="widthFix"></image>
  507. </view>
  508. </view>
  509. </view>
  510. <view class="taste-row">
  511. <view class="taste-label">
  512. 净含量
  513. </view>
  514. <view class="specification-list">
  515. <view v-for="(item, index) in list3" :key="index">
  516. <view :class="'type2 ' + [choose == index ? 'active' : '']" @click="chooseItem(index)">
  517. {{ item.name }}
  518. </view>
  519. </view>
  520. </view>
  521. </view>
  522. <view class="taste-row">
  523. <view class="taste-label">
  524. 规格
  525. </view>
  526. <view class="specification-list">
  527. <view v-for="(item, index) in list2" :key="index">
  528. <view :class="'type2 ' + [selected == index ? 'active' : '']" @click="selectedItem(index)">
  529. {{ item.name }}
  530. </view>
  531. </view>
  532. </view>
  533. </view>
  534. <view class="number-box-between">
  535. <view class="number-label">购买数量<text>(限购10件)库存1899件</text></view>
  536. <view class="calc_box">
  537. <view class="calc_btn">
  538. <image src="../../../static/less.png" mode="widthFix" />
  539. </view>
  540. <input type="number" value="1" class="calc_number" />
  541. <view class="calc_btn">
  542. <image src="../../../static/add.png" mode="widthFix" />
  543. </view>
  544. </view>
  545. </view>
  546. <view class="window-bottom">
  547. <button type="default">确定</button>
  548. </view>
  549. </view>
  550. </view>
  551. <!-- 限源预售-选择规格-弹窗 -->
  552. </view>
  553. </template>
  554. <script>
  555. import { expediteGetGoodsDetail, expediteGetGoodsComment } from '../../../common/service.js';
  556. import HeaderViewBar from '../../../components/header-view-bar/header-view-bar.vue';
  557. import popupMessage from '../../../components/addSuccess.vue';
  558. export default {
  559. components: {
  560. HeaderViewBar,
  561. popupMessage
  562. },
  563. data() {
  564. return {
  565. headerHeight: 0,
  566. headerContainerWidth: 0,
  567. scrollTop: 0,
  568. //轮播
  569. swiperList: [
  570. '../../../static/img-4.png',
  571. '../../../static/img-4.png',
  572. '../../../static/img-4.png'
  573. ],
  574. swiperCurrent: 0,
  575. star: 3, //评价,默认3星
  576. select: false, //收藏
  577. isShowAssure: false, //保障弹窗
  578. isShowSelectSpecification: false, //选择规格-弹窗
  579. //口味-单选
  580. list: [{
  581. name: '桂花坚果藕粉羹【实发1罐500g】'
  582. },
  583. {
  584. name: '坚果水果藕粉羹【实发1罐500g】'
  585. },
  586. {
  587. name: '桂花坚果藕粉羹【拍1份发两罐 拍2份发5罐同款】'
  588. },
  589. {
  590. name: '坚果水果藕粉羹【拍1份发两罐 拍2份发5罐同款】'
  591. },
  592. {
  593. name: '坚果水果+桂花坚果[(拍1份发2罐)(拍2份发5罐,2罐坚果水果+3罐…'
  594. }
  595. ],
  596. id: '0', //单选 初始化第一个高亮
  597. isShowParameter: false, //限源预售-参数-弹窗
  598. isShowPreSaleSelectSpecification: false, //限源预售-选择规格-弹窗
  599. list2: [{
  600. name: '小果55-60mm【个头偏小】'
  601. },
  602. {
  603. name: '中果55-60mm【实惠装】'
  604. },
  605. {
  606. name: '大果60-65mm【性价比】'
  607. },
  608. {
  609. name: '精选大果65mm+【超值人气爆款】'
  610. }
  611. ],
  612. selected: '3', //单选 初始化第一个高亮
  613. list3: [{
  614. name: '3斤'
  615. },
  616. {
  617. name: '5斤'
  618. },
  619. {
  620. name: '9斤'
  621. }
  622. ],
  623. choose: '2', //单选 初始化第一个高亮
  624. //倒计时
  625. timeData: {},
  626. info: {
  627. id: 0,
  628. },
  629. commentList: [],
  630. page: 1,
  631. page_num: 20,
  632. }
  633. },
  634. onLoad(option) {
  635. const id = parseInt(option.id || 0);
  636. if (id > 0) {
  637. this.info.id = id;
  638. this.getGoodsDetail();
  639. this.getGoodsComment();
  640. }
  641. },
  642. onShow() {
  643. setTimeout(() => {
  644. this.headerHeight = this.$refs['HeaderViewBar'].getHeaderStyle().headerHeight;
  645. this.headerContainerWidth = this.$refs['HeaderViewBar'].getHeaderStyle().headerContainerWidth;
  646. }, 20);
  647. },
  648. methods: {
  649. getGoodsDetail() {
  650. expediteGetGoodsDetail({
  651. data: {
  652. goods_id: this.info.id,
  653. },
  654. success: ({code, msg, data}) => {
  655. if (code == 1) {
  656. this.info = data.good;
  657. } else {
  658. uni.showToast({
  659. icon: 'none',
  660. title: msg,
  661. });
  662. }
  663. }
  664. });
  665. },
  666. getGoodsComment() {
  667. const params = {
  668. page: this.page,
  669. page_num: this.page_num,
  670. goods_id: this.info.id,
  671. };
  672. expediteGetGoodsComment({
  673. data: params,
  674. success: ({code, msg, data}) => {
  675. if (code == 1) {
  676. this.commentList == data.list;
  677. } else {
  678. uni.showToast({
  679. icon: 'none',
  680. title: msg,
  681. });
  682. }
  683. }
  684. });
  685. },
  686. // 返回顶部
  687. toTop() {
  688. uni.pageScrollTo({
  689. scrollTop: 0,
  690. duration: 100,
  691. });
  692. },
  693. //返回上一页
  694. back() {
  695. uni.navigateBack({
  696. delta: 1,
  697. })
  698. },
  699. //轮播
  700. swiperChange(e) {
  701. const {
  702. current
  703. } = e.detail;
  704. this.swiperCurrent = current;
  705. },
  706. //加入购物车成功-弹窗
  707. addCartSuccess(){
  708. uni.showToast({
  709. title: '加入购物车成功',
  710. duration: 2000
  711. });
  712. },
  713. //收藏
  714. collect: function() {
  715. this.select = !this.select;
  716. },
  717. //保障-弹窗
  718. showAssure() {
  719. this.isShowAssure = true;
  720. },
  721. closeAssure() {
  722. this.isShowAssure = false;
  723. },
  724. //选择规格-弹窗
  725. showSelectSpecification() {
  726. this.isShowSelectSpecification = true;
  727. },
  728. closeSelectSpecification() {
  729. this.isShowSelectSpecification = false;
  730. },
  731. //口味-单选
  732. choseItem: function(index) {
  733. // console.log(index)
  734. this.id = index;
  735. },
  736. //限源预售-参数-弹窗
  737. showParameter() {
  738. this.isShowParameter = true;
  739. },
  740. closeParameter() {
  741. this.isShowParameter = false;
  742. },
  743. //限源预售-选择规格-弹窗
  744. showPreSaleSelectSpecification() {
  745. this.isShowPreSaleSelectSpecification = true;
  746. },
  747. closePreSaleSelectSpecification() {
  748. this.isShowPreSaleSelectSpecification = false;
  749. },
  750. //限源预售-规格-单选
  751. selectedItem: function(index) {
  752. // console.log(index)
  753. this.selected = index;
  754. },
  755. //限源预售-净含量-单选
  756. chooseItem: function(index) {
  757. // console.log(index)
  758. this.choose = index;
  759. },
  760. //倒计时
  761. onChange(e) {
  762. this.timeData = e
  763. },
  764. //跳转购物车
  765. shoppingCart(){
  766. uni.navigateTo({
  767. url:'../../shopping-cart/shopping-cart'
  768. })
  769. },
  770. },
  771. onPageScroll(e) {
  772. this.scrollTop = e.scrollTop;
  773. }
  774. }
  775. </script>
  776. <style scoped lang="scss">
  777. @import "./product-details.css";
  778. .time {
  779. @include flex;
  780. align-items: center;
  781. &__custom {
  782. margin-top: 4px;
  783. width: 19px;
  784. height: 20px;
  785. line-height: 20px;
  786. background-color: #FC4A04 !important;
  787. border-radius: 4px;
  788. /* #ifndef APP-NVUE */
  789. display: flex;
  790. /* #endif */
  791. justify-content: center;
  792. align-items: center;
  793. &__item {
  794. color: #fff !important;
  795. font-size: 24rpx !important;
  796. text-align: center;
  797. font-weight: bold;
  798. margin: 0 !important;
  799. }
  800. }
  801. &__doc {
  802. color: #F2501A !important;
  803. padding: 0 6rpx !important;
  804. font-size: 36rpx !important;
  805. margin: 0 !important;
  806. }
  807. }
  808. </style>