productdetails.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674
  1. <template>
  2. <view>
  3. <!-- 自定义导航栏 -->
  4. <u-navbar :safeAreaInsetTop="true" :placeholder='true'>
  5. <view class="u-nav-slot u-flex" slot="left" style="display: flex;">
  6. <view class="u-flex">
  7. <u-icon name="arrow-left" size="19"></u-icon>
  8. <u-tabs duration='0' @click="click" :list="list1" lineColor='#fff' :activeStyle=" {color:'#FF1515'}"
  9. :inactiveStyle="{
  10. color:' #666666' }"></u-tabs>
  11. </view>
  12. <view class="" style="margin-left: 184rpx;" @click="share = true">
  13. <image src="static/images/share.png" style="width: 38rpx;height: 38rpx;" mode=""></image>
  14. </view>
  15. </view>
  16. </u-navbar>
  17. <!-- 商品图片 -->
  18. <image src="https://cdn.uviewui.com/uview/swiper/swiper1.png" style="width: 750rpx;height: 750rpx;" mode="">
  19. </image>
  20. <view class="back">
  21. <!-- 折扣 -->
  22. <view class="discount">
  23. <view class="top">
  24. <text class='count'>折扣价</text>
  25. <text class='money'>¥</text>
  26. <text class='money' style="font-size: 48rpx;">258</text>
  27. <text class='money'>.00</text>
  28. <text class='right'>¥328.5</text>
  29. </view>
  30. <view class="bottom">
  31. <text class="tabs">同款低价</text>
  32. <view class="title">
  33. <text class="title" selectable @longpress="onLongPress">
  34. 布兰德低温烘焙猫粮全价通用高端鲜肉成猫幼
  35. </text>
  36. </view>
  37. </view>
  38. </view>
  39. <!-- 服务 -->
  40. <view class="serve" style="margin-top: 20rpx;">
  41. <view class="top u-flex u-row-between">
  42. <view class="u-flex">
  43. <view class="change">选择</view>
  44. <view class="" style="margin-left: 20rpx;">净含量</view>
  45. </view>
  46. <view class="">
  47. <u-icon name="arrow-right" size='16'></u-icon>
  48. </view>
  49. </view>
  50. <view class="top u-flex u-row-between" style="margin-top: 36rpx;">
  51. <view class="u-flex" @click="serve=true">
  52. <view class="change">服务</view>
  53. <view class="" style="margin-left: 20rpx;">正品保障 · 极速退款 · 7天无理由退</view>
  54. </view>
  55. <view class="">
  56. <u-icon name="arrow-right" size='16'></u-icon>
  57. </view>
  58. </view>
  59. </view>
  60. <!-- 评论 -->
  61. <view class="comment">
  62. <view class="u-flex u-row-between">
  63. <text class="ping">评论</text>
  64. <view class="u-flex">
  65. <text class="strip">5000+条评论</text>
  66. <u-icon name="arrow-right" size='16'></u-icon>
  67. </view>
  68. </view>
  69. <view class="uesr u-flex u-row-between" style="margin-top: 36rpx;">
  70. <view class="u-flex">
  71. <image src="../static/images/logo.png" style="width: 52rpx;height: 52rpx;" mode=""></image>
  72. <text class="name">有**钱</text>
  73. </view>
  74. <text class="strip">2023.11.23</text>
  75. </view>
  76. <view class="content">
  77. 回购了不知道第几次了,家里猫还没吃腻呢,
  78. </view>
  79. </view>
  80. <!-- 店铺 -->
  81. <view class="store u-flex u-row-between">
  82. <view class="u-flex">
  83. <image src='../static/images/logo.png' style="width: 112rpx;height: 112rpx;" mode=""></image>
  84. <view class="" style="margin-left: 20rpx;">
  85. <view class="title">小萌优选🔥(每天0元秒杀)</view>
  86. <view class="" style='margin-top:20rpx'></view>
  87. <view class="u-flex" style='margin-top:20rpx'>
  88. <text class='num'>销售量 2384w+</text>
  89. <view class="line"></view>
  90. <text class='num'>销售量 2384w+</text>
  91. </view>
  92. </view>
  93. </view>
  94. <view class="goshop">逛逛</view>
  95. </view>
  96. <!-- 推荐 -->
  97. <view class="recommend">
  98. <view class="title">
  99. 推荐商品
  100. </view>
  101. <view class="">
  102. <image src="" mode=""></image>
  103. </view>
  104. </view>
  105. <view class="recommend">
  106. <view class="title">商品详情</view>
  107. <view class="" style="margin-top: 32rpx;margin-bottom:28rpx">规格参数</view>
  108. <view class="specification">
  109. <view class="item u-flex" style='margin-bottom:28rpx'>
  110. <view style='width:150rpx;'>主要原料</view>
  111. <text style='margin-left:58rpx'>保鲜鸡肉,鸡心,鸡肝</text>
  112. </view>
  113. <view class="item u-flex" style='margin-bottom:28rpx'>
  114. <view style='width:150rpx;'>规格</view>
  115. <text style='margin-left:58rpx'>300g</text>
  116. </view>
  117. <view class="item u-flex" style='margin-bottom:28rpx'>
  118. <view style='width:150rpx;'>保质期</view>
  119. <text style='margin-left:58rpx'>12个月</text>
  120. </view>
  121. <view class="item u-flex">
  122. <view style='width:150rpx;'>适用对象</view>
  123. <text style='margin-left:58rpx'>3个月以上的全猫种</text>
  124. </view>
  125. </view>
  126. </view>
  127. <view class="">
  128. <image src="../static/images/logo.png" style="width: 710rpx;height: 580rpx;" mode=""></image>
  129. </view>
  130. <view class="" style="height: 158rpx;"></view>
  131. <view class="fix u-flex u-row-between">
  132. <view class="u-flex" style="column-gap: 35rpx;">
  133. <view class="u-flex" style="justify-content: center;flex-direction: column;">
  134. <image src="../static/images/index/service.png" style='width:40rpx;height:40rpx' mode="">
  135. </image>
  136. <view class="ke">客服</view>
  137. </view>
  138. <view class="u-flex" style="justify-content: center;flex-direction: column;">
  139. <image src="../static/cart1.png" style='width:40rpx;height:40rpx' mode=""></image>
  140. <view class="ke">购物车</view>
  141. </view>
  142. <view class="u-flex" style="justify-content: center;flex-direction: column;">
  143. <image src="../static/images/index/attention.png" style='width:40rpx;height:40rpx' mode="">
  144. </image>
  145. <view class="ke">关注</view>
  146. </view>
  147. </view>
  148. <!-- <view class="join" @click="join">加入购物车</view>
  149. <view class="pin">立即拼团</view> -->
  150. <view class="tongzhi" @click="inform">
  151. 到货通知
  152. </view>
  153. </view>
  154. </view>
  155. <!-- 加入购物车 -->
  156. <u-popup :show="show">
  157. <view style="padding:48rpx 28rpx;box-sizing: border-box;">
  158. <view class="u-flex">
  159. <image src="../static/images/logo.png" style="width: 192rpx;height: 192rpx;" mode=""></image>
  160. <view class="" style="margin-left: 20rpx;">
  161. <view class="">¥168.00</view>
  162. <text class="guige">已选:鸡肉;2kg【单包装】</text>
  163. </view>
  164. </view>
  165. </view>
  166. </u-popup>
  167. <u-popup :show="serve">
  168. <view style="padding:48rpx 24rpx;box-sizing: border-box;background-color: #FFF3E7;position: relative;">
  169. <view class="u-flex" style="flex-direction: column;justify-content: center;">
  170. <image src="../static/images/index/serve.png" style="width: 138rpx;height: 34rpx;" mode=""></image>
  171. <text class="info">
  172. 售前售后 安心无忧购物
  173. </text>
  174. </view>
  175. <view class="" style="position: absolute;top: 48rpx;right:24rpx;" @click="serve = false">
  176. <u-icon name="close" style="width: 22rpx;height: 22rpx;"></u-icon>
  177. </view>
  178. <view class="contenta">
  179. <view class="">
  180. <view class="title">丢包丢件</view>
  181. <view class="content">快件如果在运输过程中出现损毁,将按照保价</view>
  182. </view>
  183. <view class="" style='margin-top:36rpx'>
  184. <view class="title">丢包丢件</view>
  185. <view class="content">快件如果在运输过程中出现损毁,将按照保价</view>
  186. </view>
  187. <view class="" style='margin-top:36rpx'>
  188. <view class="title">丢包丢件</view>
  189. <view class="content">快件如果在运输过程中出现损毁,将按照保价</view>
  190. </view>
  191. </view>
  192. <view class="button" @click="serve = false">
  193. 我知道了
  194. </view>
  195. </view>
  196. </u-popup>
  197. <u-popup :show="share" bgColor=' rgba(244, 244, 244, 1);'>
  198. <view style="padding:48rpx 24rpx;box-sizing: border-box;background-color: rgba(244, 244, 244, 1);">
  199. <view class="u-flex" style="flex-direction: column;justify-content: center;">
  200. <text class="info" style="font-size: 32rpx;">
  201. 分享
  202. </text>
  203. </view>
  204. <view class="" style="position: absolute;top: 48rpx;right:24rpx;">
  205. <image src="../static/images/index/bottom2.png" style="width: 40rpx;height: 40rpx;">
  206. </view>
  207. <view class="u-flex " style="justify-content: space-around;margin-top: 82rpx;">
  208. <view class="">
  209. <image src="../static/images/index/link.png" style="width: 108rpx;height: 108rpx;" mode="">
  210. </image>
  211. <view class="link">复制链接</view>
  212. </view>
  213. <view class="">
  214. <image src="../static/images/index/image.png" style="width: 108rpx;height: 108rpx;" mode="">
  215. </image>
  216. <view class="link">生成图片</view>
  217. </view>
  218. </view>
  219. <view class="button" @click="share = false" style="background: #fff;color: #555555;margin-top: 58rpx;">
  220. 取消
  221. </view>
  222. </view>
  223. </u-popup>
  224. </view>
  225. </template>
  226. <script>
  227. export default {
  228. data() {
  229. return {
  230. list1: [{
  231. name: '商品',
  232. }, {
  233. name: '评价',
  234. }, {
  235. name: '详情'
  236. }],
  237. current: 0,
  238. // 购物车
  239. show: false,
  240. //服务
  241. serve: false,
  242. //分享
  243. share: false
  244. };
  245. },
  246. methods: {
  247. click(item) {
  248. this.current = item
  249. },
  250. join() {
  251. },
  252. //通知
  253. inform() {
  254. uni.showToast({
  255. title: '当该商品有库存并上架时我们会通过微信消息提醒您',
  256. icon: 'none',
  257. duration: 2000
  258. });
  259. },
  260. //复制
  261. onLongPress(e) {
  262. // 获取长按的文本内容
  263. let text = e.target.innerText;
  264. console.log(e);
  265. // 执行复制操作
  266. uni.setClipboardData({
  267. data: text,
  268. success: () => {
  269. uni.showToast({
  270. title: '已复制,快去粘贴吧~',
  271. duration: 2000
  272. });
  273. },
  274. fail: () => {
  275. uni.showToast({
  276. title: '复制失败',
  277. icon: 'none',
  278. duration: 2000
  279. });
  280. }
  281. });
  282. }
  283. }
  284. }
  285. </script>
  286. <style lang="scss" scoped>
  287. .link {
  288. font-family: PingFangSC, PingFang SC;
  289. font-weight: 400;
  290. font-size: 28rpx;
  291. color: #555555;
  292. line-height: 40rpx;
  293. text-align: left;
  294. font-style: normal;
  295. margin-top: 16rpx;
  296. }
  297. .tongzhi {
  298. width: 422rpx;
  299. height: 76rpx;
  300. background: #FFB515;
  301. border-radius: 40rpx;
  302. font-family: PingFangSC, PingFang SC;
  303. font-weight: 500;
  304. font-size: 28rpx;
  305. color: #FFFFFF;
  306. line-height: 76rpx;
  307. text-align: center;
  308. font-style: normal;
  309. }
  310. .info {
  311. font-family: PingFangSC, PingFang SC;
  312. font-weight: 400;
  313. font-size: 20rpx;
  314. color: #222222;
  315. line-height: 28rpx;
  316. text-align: left;
  317. font-style: normal;
  318. margin-top: 18rpx;
  319. }
  320. .button {
  321. // width: 662rpx;
  322. height: 88rpx;
  323. background: #F83224;
  324. border-radius: 44rpx;
  325. margin-top: 24rpx;
  326. font-family: PingFangSC, PingFang SC;
  327. font-weight: 500;
  328. font-size: 32rpx;
  329. color: #FFFFFF;
  330. line-height: 88rpx;
  331. text-align: center;
  332. font-style: normal;
  333. }
  334. .contenta {
  335. width: 702rpx;
  336. // height: 590rpx;
  337. background: #FFFFFF;
  338. border-radius: 20rpx;
  339. margin-top: 26rpx;
  340. padding: 28rpx 24rpx;
  341. box-sizing: border-box;
  342. .title {
  343. font-family: PingFangSC, PingFang SC;
  344. font-weight: 500;
  345. font-size: 30rpx;
  346. color: #222222;
  347. line-height: 42rpx;
  348. text-align: left;
  349. font-style: normal;
  350. }
  351. .content {
  352. font-family: PingFangSC, PingFang SC;
  353. font-weight: 400;
  354. font-size: 26rpx;
  355. color: #222222;
  356. line-height: 36rpx;
  357. text-align: left;
  358. font-style: normal;
  359. margin-top: 20rpx;
  360. }
  361. }
  362. .back {
  363. background-color: #F4F4F4;
  364. padding: 20rpx;
  365. box-sizing: border-box;
  366. .guige {}
  367. .fix {
  368. width: 750rpx;
  369. height: 158rpx;
  370. background: #FFFFFF;
  371. padding: 14rpx 28rpx;
  372. box-sizing: border-box;
  373. position: fixed;
  374. bottom: 0;
  375. left: 0;
  376. .ke {
  377. font-family: PingFangSC, PingFang SC;
  378. font-weight: 400;
  379. font-size: 20rpx;
  380. color: #333333;
  381. line-height: 28rpx;
  382. text-align: left;
  383. font-style: normal;
  384. }
  385. .join {
  386. width: 208rpx;
  387. height: 76rpx;
  388. border-radius: 40rpx;
  389. border: 1rpx solid #FF1515;
  390. font-family: PingFangSC, PingFang SC;
  391. font-weight: 500;
  392. font-size: 28rpx;
  393. color: #F83224;
  394. line-height: 76rpx;
  395. text-align: left;
  396. font-style: normal;
  397. text-align: center;
  398. }
  399. .pin {
  400. width: 208rpx;
  401. height: 76rpx;
  402. background: #F83224;
  403. border-radius: 40rpx;
  404. font-family: PingFangSC, PingFang SC;
  405. font-weight: 500;
  406. font-size: 28rpx;
  407. color: #FFFFFF;
  408. line-height: 76rpx;
  409. text-align: center;
  410. font-style: normal;
  411. }
  412. }
  413. // 规格
  414. .specification {
  415. width: 670rpx;
  416. height: 280rpx;
  417. background: #F4F4F4;
  418. padding: 24rpx 22rpx;
  419. box-sizing: border-box;
  420. .item {
  421. font-family: PingFangSC, PingFang SC;
  422. font-weight: 400;
  423. font-size: 26rpx;
  424. color: #333333;
  425. line-height: 36rpx;
  426. text-align: left;
  427. font-style: normal;
  428. }
  429. }
  430. // 推荐
  431. .recommend {
  432. width: 710rpx;
  433. height: 476rpx;
  434. background: #FFFFFF;
  435. border-radius: 16rpx;
  436. padding: 24rpx 20rpx;
  437. margin-top: 20rpx;
  438. box-sizing: border-box;
  439. .title {
  440. font-family: PingFangSC, PingFang SC;
  441. font-weight: 500;
  442. font-size: 28rpx;
  443. color: #222222;
  444. line-height: 40rpx;
  445. text-align: left;
  446. font-style: normal;
  447. }
  448. }
  449. //店铺
  450. .store {
  451. width: 710rpx;
  452. height: 160rpx;
  453. background: #FFFFFF;
  454. border-radius: 16rpx;
  455. padding: 24rpx 20rpx;
  456. box-sizing: border-box;
  457. margin-top: 20rpx;
  458. .line {
  459. background: rgba(151, 151, 151, 1);
  460. width: 4rpx;
  461. height: 20rpx;
  462. margin: 0 18rpx;
  463. }
  464. .num {
  465. font-family: SFPro, SFPro;
  466. font-weight: 400;
  467. font-size: 20rpx;
  468. color: #777777;
  469. line-height: 24rpx;
  470. text-align: left;
  471. font-style: normal;
  472. }
  473. .goshop {
  474. width: 108rpx;
  475. height: 52rpx;
  476. border-radius: 26rpx;
  477. border: 1rpx solid #FF1515;
  478. font-family: PingFangSC, PingFang SC;
  479. font-weight: 400;
  480. font-size: 24rpx;
  481. color: #F83224;
  482. line-height: 52rpx;
  483. text-align: center;
  484. font-style: normal;
  485. }
  486. }
  487. // 评论
  488. .comment {
  489. width: 710rpx;
  490. height: 356rpx;
  491. background: #FFFFFF;
  492. border-radius: 16rpx;
  493. margin-top: 20rpx;
  494. padding: 24rpx 20rpx;
  495. box-sizing: border-box;
  496. .content {
  497. margin-top: 20rpx;
  498. font-family: PingFangSC, PingFang SC;
  499. font-weight: 400;
  500. font-size: 26rpx;
  501. color: #444444;
  502. line-height: 36rpx;
  503. text-align: left;
  504. font-style: normal;
  505. height: 112rpx;
  506. overflow: hidden;
  507. text-overflow: ellipsis;
  508. white-space: wrap;
  509. -webkit-line-clamp: 3
  510. }
  511. .name {
  512. font-family: PingFangSC, PingFang SC;
  513. font-weight: 400;
  514. font-size: 24rpx;
  515. color: #222222;
  516. line-height: 34rpx;
  517. text-align: left;
  518. font-style: normal;
  519. margin-left: 16rpx;
  520. }
  521. .ping {
  522. font-family: PingFangSC, PingFang SC;
  523. font-weight: 500;
  524. font-size: 28rpx;
  525. color: #222222;
  526. line-height: 40rpx;
  527. text-align: left;
  528. font-style: normal;
  529. }
  530. .strip {
  531. font-family: PingFangSC, PingFang SC;
  532. font-weight: 400;
  533. font-size: 24rpx;
  534. color: #444444;
  535. line-height: 34rpx;
  536. text-align: left;
  537. font-style: normal;
  538. }
  539. }
  540. //服务
  541. .serve {
  542. width: 710rpx;
  543. height: 180rpx;
  544. background: #FFFFFF;
  545. border-radius: 16rpx;
  546. padding: 32rpx 20rpx;
  547. box-sizing: border-box;
  548. .top {
  549. .change {
  550. font-family: PingFangSC, PingFang SC;
  551. font-weight: 400;
  552. font-size: 28rpx;
  553. color: #666666;
  554. line-height: 40rpx;
  555. text-align: left;
  556. font-style: normal;
  557. }
  558. }
  559. }
  560. //折扣
  561. .discount {
  562. position: relative;
  563. height: 312rpx;
  564. .top {
  565. width: 710rpx;
  566. height: 124rpx;
  567. background: linear-gradient(295deg, #FB6662 0%, #FD403B 100%);
  568. border-radius: 16rpx 16rpx 0 0;
  569. padding: 20rpx;
  570. box-sizing: border-box;
  571. line-height: 98rpx;
  572. .count {
  573. font-family: PingFangSC, PingFang SC;
  574. font-weight: 400;
  575. font-size: 20rpx;
  576. color: #FFFFFF;
  577. text-align: left;
  578. font-style: normal;
  579. }
  580. .money {
  581. font-size: 20rpx;
  582. font-family: HarmonyOS_Sans_Medium;
  583. font-size: 20rpx;
  584. color: #FFFFFF;
  585. text-align: left;
  586. font-style: normal;
  587. margin-left: 8rpx
  588. }
  589. .right {
  590. font-family: HarmonyOS_Sans;
  591. font-size: 24rpx;
  592. color: #FFFFFF;
  593. text-align: left;
  594. font-style: normal;
  595. text-decoration-line: line-through;
  596. margin-left: 16rpx
  597. }
  598. }
  599. .bottom {
  600. width: 710rpx;
  601. height: 208rpx;
  602. background: #FFFFFF;
  603. border-radius: 16rpx;
  604. position: absolute;
  605. top: 104rpx;
  606. z-index: 2;
  607. padding: 28rpx 20rpx;
  608. box-sizing: border-box;
  609. .title {
  610. margin-top: 24rpx;
  611. font-family: PingFangSC, PingFang SC;
  612. font-weight: 500;
  613. font-size: 32rpx;
  614. color: #222222;
  615. line-height: 44rpx;
  616. text-align: left;
  617. font-style: normal;
  618. }
  619. }
  620. .tabs {
  621. // width: 104rpx;
  622. height: 40rpx;
  623. background: rgba(255, 21, 21, 0.1);
  624. border-radius: 4rpx;
  625. padding: 4rpx 8rpx;
  626. font-family: PingFangSC, PingFang SC;
  627. font-weight: 400;
  628. font-size: 22rpx;
  629. color: #FF1515;
  630. line-height: 40rpx;
  631. text-align: center;
  632. font-style: normal;
  633. }
  634. }
  635. }
  636. </style>