productdetails.vue 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633
  1. <template>
  2. <view class="page">
  3. <!-- 页面内容 -->
  4. <!-- 自定义导航栏 -->
  5. <u-navbar :safeAreaInsetTop="true" :placeholder="true">
  6. <view class="u-nav-slot u-flex" slot="left" style="display: flex">
  7. <view class="u-flex">
  8. <u-icon name="arrow-left" size="19" @click="returnindex"></u-icon>
  9. <u-tabs :duration="duration" @click="scrollToPosition" :list="list1" lineColor="#fff"
  10. :activeStyle="{ color: '#FF1515' }" :inactiveStyle="{
  11. color: ' #666666',
  12. }"></u-tabs>
  13. </view>
  14. <!-- <view class="" style="margin-left: 184rpx;" @click="share = true">
  15. <image src="static/images/share.png" style="width: 38rpx;height: 38rpx;" mode=""></image>
  16. </view> -->
  17. </view>
  18. <view class="u-nav-slot u-flex" slot="right" style="display: flex">
  19. <view class="" style="" @click="sharea">
  20. <image src="static/images/share.png" style="width: 38rpx; height: 38rpx" mode=""></image>
  21. </view>
  22. <view class="" style="width: 200rpx"></view>
  23. </view>
  24. </u-navbar>
  25. <!-- 商品图片 -->
  26. <scroll-view ref="scrollView" scroll-y="true" style="min-height: 100vh" :scroll-into-view="toView"
  27. scroll-with-animation="true">
  28. <view class="uni-margin-wrap" id="scroll0">
  29. <swiper class="swiper" circular :indicator-dots="false" :autoplay="true">
  30. <swiper-item v-if="goodinfo.video">
  31. <video style="width: 750rpx; height: 750rpx" :src="goodinfo.video"></video>
  32. </swiper-item>
  33. <template v-if="goodinfo.images">
  34. <swiper-item v-for="(item, idx) in goodinfo.images.split(',')" :key="idx">
  35. <image :src="goodinfo.image" style="width: 750rpx; height: 750rpx" mode=""></image>
  36. </swiper-item>
  37. </template>
  38. </swiper>
  39. </view>
  40. <view class="back">
  41. <!-- 折扣 -->
  42. <view class="discount">
  43. <view class="top">
  44. <text class="count" v-if="goodinfo.is_discount == 0">{{
  45. i18n.Discounted
  46. }}</text>
  47. <text class="money">¥</text>
  48. <text class="money" style="font-size: 48rpx">{{
  49. goodinfo.discount_price.slice(0, -3)
  50. }}</text>
  51. <text class="money">{{ goodinfo.discount_price.slice(-3) }}</text>
  52. <!-- <text class="right" v-if="goodinfo.is_discount == 0">¥{{ goodinfo.price }}</text> -->
  53. <text class="right" v-if="goodinfo.is_discount == 0">¥{{ goodinfo.price * value }}</text>
  54. </view>
  55. <view class="bottom">
  56. <view class="u-flex" style="column-gap: 16rpx">
  57. <div v-for="(tab, idx) in goodinfo.label_arr" :key="idx">
  58. <text v-if="language == 'zh-CN'" class="tabs">{{
  59. tab.name_cn
  60. }}</text>
  61. <text v-if="language == 'en-US'" class="tabs">{{
  62. tab.name_en
  63. }}</text>
  64. <text v-if="language == 'es-ES'" class="tabs">{{
  65. tab.name_es
  66. }}</text>
  67. <text v-if="language == 'it-IT'" class="tabs">{{
  68. tab.name_ita
  69. }}</text>
  70. </div>
  71. </view>
  72. <view class="">
  73. <text class="title" v-if="language == 'zh-CN'">
  74. {{ goodinfo.name_cn }}
  75. </text>
  76. <text class="title" selectable @longpress="onLongPress" v-if="language == 'en-US'">
  77. {{ goodinfo.name_en }}
  78. </text>
  79. <text class="title" selectable @longpress="onLongPress" v-if="language == 'es-ES'">
  80. {{ goodinfo.name_es }}
  81. </text>
  82. <text class="title" selectable @longpress="onLongPress" v-if="language == 'it-IT'">
  83. {{ goodinfo.name_ita }}
  84. </text>
  85. </view>
  86. </view>
  87. </view>
  88. <!-- 服务 -->
  89. <view class="serve" style="margin-top: 20rpx">
  90. <view class="top u-flex u-row-between" @click="sele">
  91. <view class="u-flex">
  92. <view class="change">{{ i18n.Sele }}</view>
  93. <view class="" style="margin-left: 20rpx">
  94. {{ selectArr.length > 0 ? selectArr.join(",") : i18n.Sele }}
  95. </view>
  96. </view>
  97. <view class="">
  98. <u-icon name="arrow-right" size="16"></u-icon>
  99. </view>
  100. </view>
  101. <view class="top u-flex u-row-between" style="margin-top: 36rpx" @click="openfu">
  102. <view class="u-flex">
  103. <view class="change">{{ i18n.service }}</view>
  104. <view v-if="language == 'zh-CN'" class="" style="margin-left: 20rpx">{{ content.name_cn }}
  105. </view>
  106. <view v-if="language == 'en-US'" class="" style="margin-left: 20rpx">{{ content.name_en }}
  107. </view>
  108. <view v-if="language == 'es-ES'" class="" style="margin-left: 20rpx">{{ content.name_es }}
  109. </view>
  110. <view v-if="language == 'it-IT'" class="" style="margin-left: 20rpx">{{ content.name_ita }}
  111. </view>
  112. </view>
  113. <view class="">
  114. <u-icon name="arrow-right" size="16"></u-icon>
  115. </view>
  116. </view>
  117. </view>
  118. <!-- 评论 -->
  119. <view class="comment" ref="targetPosition" id="scroll1">
  120. <view class="u-flex u-row-between">
  121. <text class="ping">{{ i18n.review }}</text>
  122. <view class="u-flex" @click="tocomment">
  123. <text class="strip">{{ total }}{{ i18n.article + i18n.review }}</text>
  124. <u-icon name="arrow-right" size="16"></u-icon>
  125. </view>
  126. </view>
  127. <view class="" v-for="(item, idx) in commentlist" :key="idx">
  128. <view class="uesr u-flex u-row-between" style="margin-top: 36rpx">
  129. <view class="u-flex">
  130. <image :src="item.member.avatar" style="width: 52rpx; height: 52rpx" mode="">
  131. </image>
  132. <text class="name">{{ item.member.nickname }}</text>
  133. </view>
  134. <text class="strip">{{ item.created_at }}</text>
  135. </view>
  136. <view class="content">
  137. {{ item.content }}
  138. </view>
  139. <view class="sku" style="margin-top: 16rpx">{{
  140. item.sku_item.item
  141. }}</view>
  142. </view>
  143. </view>
  144. <!-- 店铺 -->
  145. <view class="store u-flex u-row-between">
  146. <view class="u-flex">
  147. <image :src="goodinfo.merchant.image" style="width: 112rpx; height: 112rpx" mode=""></image>
  148. <view class="" style="margin-left: 20rpx">
  149. <view class="title" style="width: 600">{{
  150. goodinfo.merchant.merchant_name
  151. }}</view>
  152. <view class="redback u-flex">
  153. <uni-rate network allow-half :readonly="true" active-color="red"
  154. color="rgba(255, 27, 0, 0.5)" :size="8" v-model="rate" max="5" />
  155. <text style="margin-left: 8rpx">{{ rate }}</text>
  156. </view>
  157. <view class="" style="margin-top: 20rpx"></view>
  158. <view class="u-flex" style="margin-top: 20rpx">
  159. <text class="num">{{ i18n.Salesvolume }} {{ goodinfo.merchant.sale_num }}</text>
  160. <view class="line"></view>
  161. <!-- 评价总数 -->
  162. <text class="num">{{ i18n.review }} {{ goodinfo.merchant.comment_num }}</text>
  163. </view>
  164. </view>
  165. </view>
  166. <view class="goshop" @click="goshop(goodinfo.merchant.id)">{{
  167. i18n.stroll
  168. }}</view>
  169. </view>
  170. <!-- 推荐 -->
  171. <view class="recommend">
  172. <view class="title">
  173. {{ i18n.Recommended }}
  174. </view>
  175. <view class="" style="margin-top: 10rpx">
  176. <swiper style="height: 400rpx" class="swiper" circular :indicator-dots="true" :autoplay="true">
  177. <swiper-item v-for="(parent, index) in swiptlist" :key="index">
  178. <view class="u-flex swiper-item u-row-between">
  179. <view class="" v-for="(child, idx) in parent" @click="detail(child.id)" :key="idx">
  180. <image :src="child.image" style="
  181. width: 214rpx;
  182. height: 214rpx;
  183. border-radius: 10rpx;
  184. " mode="">
  185. </image>
  186. <view class="over" style="
  187. width: 214rpx;
  188. margin-top: 14rpx;
  189. font-style: normal;
  190. font-size: 26rpx;
  191. " v-if="language == 'zh-CN'">
  192. {{ child.name_cn }}
  193. </view>
  194. <view class="over" style="
  195. width: 214rpx;
  196. margin-top: 14rpx;
  197. font-style: normal;
  198. font-size: 26rpx;
  199. " v-if="language == 'en-US'">
  200. {{ child.name_en }}
  201. </view>
  202. <view class="over" style="
  203. width: 214rpx;
  204. margin-top: 14rpx;
  205. font-style: normal;
  206. font-size: 26rpx;
  207. " v-if="language == 'es-ES'">
  208. {{ child.name_es }}
  209. </view>
  210. <view class="over" style="
  211. width: 214rpx;
  212. margin-top: 14rpx;
  213. font-style: normal;
  214. font-size: 26rpx;
  215. " v-if="language == 'it-IT'">
  216. {{ child.name_ita }}
  217. </view>
  218. <view class="" style="margin-top: 12rpx">
  219. <span
  220. style="color: rgba(204, 51, 0, 1); font-size: 26rpx">¥{{ child.price }}</span>
  221. </view>
  222. </view>
  223. </view>
  224. </swiper-item>
  225. </swiper>
  226. </view>
  227. </view>
  228. <view class="recommend" id="scroll2">
  229. <view class="title">{{ i18n.Productdetails }}</view>
  230. <view class="" style="margin-top: 32rpx; margin-bottom: 28rpx; font-size: 26rpx">
  231. {{ i18n.Specification }}
  232. </view>
  233. <view class="specification">
  234. <view class="item u-flex" style="margin-bottom: 28rpx" v-for="(item, idx) in goodinfo.parameter"
  235. :key="idx">
  236. <view style="width: 150rpx" v-if="language == 'zh-CN'">{{ item.name }}</view>
  237. <text style="margin-left: 58rpx" v-if="language == 'zh-CN'">{{ item.value }}</text>
  238. <view style="width: 150rpx" v-if="language == 'en-US'">{{ item.name_en }}</view>
  239. <text style="margin-left: 58rpx" v-if="language == 'en-US'">{{ item.value_en }}</text>
  240. <view style="width: 150rpx" v-if="language == 'es-ES'">{{ item.name_es }}</view>
  241. <text style="margin-left: 58rpx" v-if="language == 'es-ES'">{{ item.value_es }}</text>
  242. <view style="width: 150rpx" v-if="language == 'it-IT'">{{ item.name_ita }}</view>
  243. <text style="margin-left: 58rpx" v-if="language == 'it-IT'">{{ item.value_ita }}</text>
  244. </view>
  245. </view>
  246. <view class="" style="margin-top: 28rpx">
  247. <view v-if="language == 'zh-CN'" class="">
  248. <u-parse :content="goodinfo.detail_cn"></u-parse>
  249. </view>
  250. <view v-if="language == 'en-US'" class="">
  251. <u-parse :content="goodinfo.detail_en"></u-parse>
  252. </view>
  253. <view v-if="language == 'es-ES'" class="">
  254. <u-parse :content="goodinfo.detail_es"></u-parse>
  255. </view>
  256. <view v-if="language == 'it-IT'" class="">
  257. <u-parse :content="goodinfo.detail_ita"></u-parse>
  258. </view>
  259. <!-- <image :src="goodinfo.image" style="width: 100%; height: 580rpx" mode=""></image> -->
  260. </view>
  261. </view>
  262. <view class="" style="height: 158rpx"></view>
  263. <view class="fix u-flex u-row-between">
  264. <view class="u-flex" style="column-gap: 35rpx">
  265. <view class="u-flex" style="justify-content: center; flex-direction: column" @click="chat">
  266. <image src="../static/images/index/service.png" style="width: 40rpx; height: 40rpx" mode="">
  267. </image>
  268. <view class="ke">{{ i18n.Customer }}</view>
  269. </view>
  270. <view class="u-flex" style="justify-content: center; flex-direction: column" @click="shopping">
  271. <image src="../static/cart1.png" style="width: 40rpx; height: 40rpx" mode="">
  272. </image>
  273. <view class="ke">{{ i18n.Shopping }}</view>
  274. </view>
  275. <view class="u-flex" style="
  276. justify-content: center;
  277. flex-direction: column;
  278. width: 70rpx;
  279. " @click="fllow">
  280. <image v-if="goodinfo.is_interest == 1" src="../static/images/index/attention.png"
  281. style="width: 40rpx; height: 40rpx" mode=""></image>
  282. <image v-if="goodinfo.is_interest == 0" src="../static/images/index/bottom1.png"
  283. style="width: 40rpx; height: 40rpx" mode="">
  284. </image>
  285. <view v-if="goodinfo.is_interest == 1" class="ke">{{
  286. i18n.follow
  287. }}</view>
  288. <view v-if="goodinfo.is_interest == 0" class="ke" style="color: rgba(248, 50, 36, 1)">
  289. {{ i18n.Followed }}
  290. </view>
  291. </view>
  292. </view>
  293. <view v-if="sku_info.stock_total == 0" class="tongzhi" @click="inform">
  294. {{ i18n.notification }}
  295. </view>
  296. <view v-if="sku_info.stock_total != 0" class="join" @click="join(0)">{{ i18n.Addtocart }}</view>
  297. <view v-if="sku_info.stock_total != 0" class="pin" @click="join(1)">{{
  298. i18n.grouping
  299. }}</view>
  300. </view>
  301. </view>
  302. </scroll-view>
  303. <!-- 加入购物车 -->
  304. <u-popup :round="10" :show="show">
  305. <view style="padding: 48rpx 28rpx; box-sizing: border-box; position: relative">
  306. <view class="u-flex">
  307. <image :src="
  308. sku_info.image==null ? goodinfo.image : sku_info.image
  309. " style="width: 192rpx; height: 192rpx" mode="">
  310. </image>
  311. <view class="" style="margin-left: 20rpx">
  312. <view class="">
  313. <text class="read">¥</text>
  314. <text class="read" style="font-size: 40rpx; font-weight: 600">{{
  315. (Number(sku_info.discount_price * 100) * Number(value * 100)) /
  316. 10000 ||
  317. (Number(goodinfo.discount_price * 100) * Number(value * 100)) /
  318. 10000
  319. }}</text>
  320. <!-- <text class="read" v-if="goodinfo.is_discount==0">{{(goodinfo.discount_price * value).slice(-3)}}</text> -->
  321. <!-- <text class="read" style="font-size: 40rpx;font-weight: 600;"
  322. v-if="goodinfo.is_discount == 1">{{
  323. (Number(sku_info.price * 100) * Number(value * 100)) /
  324. 10000 ||
  325. (Number(goodinfo.price * 100) * Number(value * 100)) / 10000
  326. }}</text> -->
  327. <!-- <text class="read" v-if="goodinfo.is_discount==1">{{(goodinfo.price * value).slice(-3)}}</text> -->
  328. <!-- <text class="read" style="font-size: 40rpx;" >{{(Number(goodinfo.price) * Number(value)).toString()}}</text> -->
  329. </view>
  330. <text class="guige">{{ i18n.Selected }}:{{
  331. selectArr.join(",") || i18n.selection
  332. }}</text>
  333. </view>
  334. </view>
  335. <view class="" style="position: absolute; top: 48rpx; right: 28rpx" @click="close">
  336. <u-icon name="close" color="#000" size="28"></u-icon>
  337. </view>
  338. <view class="" v-for="(item, index) in goodinfo.sku">
  339. <view v-if="language == 'zh-CN'" class="title1" style="margin-top: 40rpx; margin-bottom: 32rpx">
  340. {{ item.name }}
  341. </view>
  342. <view v-if="language == 'en-US'" class="title1" style="margin-top: 40rpx; margin-bottom: 32rpx">
  343. {{ item.name_en }}
  344. </view>
  345. <view v-if="language == 'es-ES'" class="title1" style="margin-top: 40rpx; margin-bottom: 32rpx">
  346. {{ item.name_es }}
  347. </view>
  348. <view v-if="language == 'it-IT'" class="title1" style="margin-top: 40rpx; margin-bottom: 32rpx">
  349. {{ item.name_ita }}
  350. </view>
  351. <view class="u-flex" style="flex-wrap: wrap">
  352. <view style="margin-right: 18rpx; margin-bottom: 18rpx" class=""
  353. :class="selectArr[index] == child.name || selectArr[index] == child.name_en || selectArr[index] == child.name_es ||selectArr[index] == child.name_ita? 'acttab' : 'tabs'"
  354. v-for="(child, idx) in item.values" :key="idx" @click="actabs(index, child, item)">
  355. <text v-if="language == 'zh-CN'">{{child.name}}</text>
  356. <text v-if="language == 'en-US'">{{child.name_en}}</text>
  357. <text v-if="language == 'es-ES'">{{child.name_es}}</text>
  358. <text v-if="language == 'it-IT'">{{child.name_ita}}</text>
  359. </view>
  360. </view>
  361. </view>
  362. <view class="u-flex u-row-between" style="margin-top: 30rpx">
  363. <text class="title1">{{ i18n.number }}</text>
  364. <u-number-box v-model="value" @change="valChange"></u-number-box>
  365. </view>
  366. <view class="" style="height: 200rpx"></view>
  367. <view class="bottoma">
  368. <view v-if="shopcar == 0" class="btn" @click="joincart">
  369. {{ i18n.Addtocart }}
  370. </view>
  371. <view v-if="shopcar == 1" class="btn" @click="order">
  372. {{ i18n.Buynow }}
  373. </view>
  374. <view v-if="shopcar == 2" class="btn" @click="close">
  375. {{ i18n.enter }}
  376. </view>
  377. </view>
  378. </view>
  379. </u-popup>
  380. <u-popup :show="serve" :round="20">
  381. <view style="
  382. padding: 48rpx 24rpx;
  383. box-sizing: border-box;
  384. background-color: #fff3e7;
  385. position: relative;
  386. border-radius: 20rpx 20rpx 0 0;
  387. ">
  388. <view class="u-flex" style="flex-direction: column; justify-content: center">
  389. <image src="../static/images/index/serve.png" style="width: 138rpx; height: 34rpx" mode=""></image>
  390. <text class="info"> {{ i18n.sales }} </text>
  391. </view>
  392. <view class="" style="position: absolute; top: 48rpx; right: 24rpx" @click="close()">
  393. <u-icon name="close" style="width: 22rpx; height: 22rpx"></u-icon>
  394. </view>
  395. <view class="contenta">
  396. <view class="" v-if="language == 'zh-CN'">
  397. <u-parse :content="content.content_cn"></u-parse>
  398. </view>
  399. <view class="" v-if="language == 'en-US'">
  400. <u-parse :content="content.content_en"></u-parse>
  401. </view>
  402. <view class="" v-if="language == 'es-ES'">
  403. <u-parse :content="content.content_es"></u-parse>
  404. </view>
  405. <view class="" v-if="language == 'it-IT'">
  406. <u-parse :content="content.content_ita"></u-parse>
  407. </view>
  408. </view>
  409. <view class="button" @click="close()">
  410. {{ i18n.know }}
  411. </view>
  412. </view>
  413. </u-popup>
  414. <u-popup :round="10" :show="share" bgColor=" rgba(244, 244, 244, 1);">
  415. <view style="
  416. padding: 48rpx 24rpx;
  417. box-sizing: border-box;
  418. background-color: rgba(244, 244, 244, 1);
  419. border-radius: 10px 10px 0 0;
  420. ">
  421. <view class="u-flex u-row-between" style="">
  422. <view class="" style="width: 28px; height: 28px"></view>
  423. <text class="info" style="font-size: 32rpx">
  424. {{ i18n.shar }}
  425. </text>
  426. <image @click="toxieyi" src="../static/images/index/bottom2.png"
  427. style="width: 40rpx; height: 40rpx">
  428. </image>
  429. </view>
  430. <!-- <view class="" style="position: absolute;top: 48rpx;right:24rpx;">
  431. </view> -->
  432. <view class="u-flex" style="margin-top: 82rpx; padding: 0 140rpx; justify-content: center">
  433. <!-- <view class="" @click="copylink">
  434. <image src="../static/images/index/link.png" style="width: 108rpx; height: 108rpx" mode="">
  435. </image>
  436. <view class="link">{{ i18n.Copylink }}</view>
  437. </view> -->
  438. <view class="u-row-center" style="display: flex; flex-direction: column; align-items: center"
  439. @click="builder">
  440. <image src="../static/images/index/image.png" style="width: 108rpx; height: 108rpx" mode="">
  441. </image>
  442. <view class="link">{{ i18n.Generatepicture }}</view>
  443. </view>
  444. </view>
  445. <view class="button" @click="close" style="background: #fff; color: #555555; margin-top: 58rpx">
  446. {{ i18n.Cancel }}
  447. </view>
  448. </view>
  449. </u-popup>
  450. <u-popup :show="imagea" bgColor=" rgba(244, 244, 244, 0);" mode="center"
  451. :customStyle="{ alignItems: 'center' }">
  452. <view class="u-fle" style="display: flex; justify-content: flex-end; width: 100%">
  453. <u-icon name="close" @click="close()" color="#fff" size="28"></u-icon>
  454. </view>
  455. <image :src="picture2" mode="widthFix"></image>
  456. <view class="button" style="width: 658rpx" @click="saveImage">{{
  457. i18n.album
  458. }}</view>
  459. </u-popup>
  460. <l-painter custom-style="position: fixed; left: 200%" ref="poster"
  461. css="width: 538rpx; height:900rpx; background: #fff;padding:24rpx">
  462. <l-painter-image :src="goodinfo.image" css="width: 490rpx; height: 490rpx" />
  463. <l-painter-text text="¥" css=" padding-top: 20rpx;color:#F83224;" />
  464. <l-painter-text :text="goodinfoyuan"
  465. css="text-align:center; padding-top: 20rpx;color:#F83224; font-size: 26rpx" />
  466. <l-painter-text :text="goodinfoname" css=" padding-top: 20rpx;display:block" />
  467. <l-painter-qrcode :text="'https://cbec.hdlkeji.com/cbec?id=' + id + '&userid=' + userid"
  468. css="width: 132rpx; height: 132rpx;margin-top:44rpx;margin-left:174rpx" />
  469. <l-painter-text :text="i18n.identify"
  470. css=" padding-top: 20rpx;text-align:center;display:block;color:#777777" />
  471. </l-painter>
  472. </view>
  473. </template>
  474. <script>
  475. import WebIM from "@/newSDK/Easemob-chat-4.1.7.js";
  476. import {
  477. conn
  478. } from "@/utils/WebIM";
  479. import list from "../uview-ui/libs/config/props/list";
  480. export default {
  481. data() {
  482. return {
  483. share_merchant_id: "",
  484. toView: "",
  485. imagea: false,
  486. goodinfoname: "",
  487. goodinfoyuan: "",
  488. current: 0,
  489. // 购物车
  490. show: false,
  491. //服务
  492. serve: false,
  493. //分享
  494. share: false,
  495. value: 1, //步进器的值
  496. swiptlist: [], //推荐列表
  497. actab: 0,
  498. id: "", //商品id
  499. language: "zh-CN",
  500. goodinfo: {}, //商品详情
  501. duration: 0, //tabs选项
  502. actidx: 0,
  503. subIndex: [],
  504. selectArr: [],
  505. shopcar: "",
  506. sku_info: {},
  507. commentlist: [],
  508. total: "",
  509. rate: 5,
  510. content: {},
  511. bao: "",
  512. picture2: "",
  513. userid: "",
  514. fu: "",
  515. name_c: "",
  516. childA: ''
  517. };
  518. },
  519. computed: {
  520. i18n() {
  521. return this.$t("index");
  522. },
  523. list1() {
  524. var List = [{
  525. name: this.i18n.mineCommodity,
  526. },
  527. {
  528. name: this.i18n.evaluate,
  529. },
  530. {
  531. name: this.i18n.particulars,
  532. },
  533. ];
  534. return List;
  535. },
  536. },
  537. onLoad(options) {
  538. console.log(options);
  539. if (options.q && options.q != "undefined") {
  540. // 获取到二维码原始链接内容
  541. const qrUrl = decodeURIComponent(options.q);
  542. //此处就是我们要获取的参数 json,通过方法解析
  543. let jsonUrl = this.GetwxUrlParam(qrUrl);
  544. //比如我要得到id的值,直接取值即可
  545. console.log("jsonUrl", jsonUrl);
  546. let id = jsonUrl.id;
  547. this.share_merchant_id = jsonUrl.userid;
  548. this.id = id;
  549. this.comment();
  550. this.detail(this.id);
  551. } else {
  552. if (uni.getStorageSync("user_info")) {
  553. var user_info = uni.getStorageSync("user_info");
  554. this.userid = user_info.id;
  555. console.log(this.userid);
  556. }
  557. this.id = options.id;
  558. this.comment();
  559. this.detail(this.id);
  560. }
  561. },
  562. onShow() {
  563. if (uni.getStorageSync("language") != "") {
  564. this.language = uni.getStorageSync("language");
  565. }
  566. this.recommend();
  567. this.guarantee();
  568. },
  569. mounted() {
  570. this.$refs.poster.canvasToTempFilePathSync({
  571. fileType: "jpg",
  572. quality: 1,
  573. success: (res) => {
  574. // console.log(`mounted`, res.tempFilePath)
  575. this.picture2 = res.tempFilePath;
  576. },
  577. });
  578. },
  579. methods: {
  580. //返佣规则
  581. toxieyi() {
  582. uni.navigateTo({
  583. url: "/pageB/xieyi?code=" + "rebate_proportion",
  584. });
  585. },
  586. //解析链接地址
  587. GetwxUrlParam(url) {
  588. let theRequest = {};
  589. if (url.indexOf("#") != -1) {
  590. const str = url.split("#")[1];
  591. const strs = str.split("&");
  592. for (let i = 0; i < strs.length; i++) {
  593. theRequest[strs[i].split("=")[0]] = decodeURI(strs[i].split("=")[1]);
  594. }
  595. } else if (url.indexOf("?") != -1) {
  596. const str = url.split("?")[1];
  597. const strs = str.split("&");
  598. for (let i = 0; i < strs.length; i++) {
  599. theRequest[strs[i].split("=")[0]] = decodeURI(strs[i].split("=")[1]);
  600. }
  601. }
  602. return theRequest;
  603. },
  604. //分享
  605. onShareAppMessage(res) {
  606. if (res.from === "button") {
  607. // 来自页面内分享按钮
  608. console.log(res.target);
  609. }
  610. return {
  611. title: "自定义分享标题",
  612. path: "/pageA/productdetails?id=" + this.id,
  613. };
  614. },
  615. //保存到手机相册
  616. saveImage() {
  617. var that = this;
  618. var fileManager = uni.getFileSystemManager();
  619. fileManager.writeFile({
  620. filePath: wx.env.USER_DATA_PATH + "/img.jpg", // 指定图片的临时路径
  621. data: this.picture2.slice(23), // 要写入的文本或二进制数据
  622. encoding: "base64", // 指定写入文件的字符编码
  623. success: (res) => {
  624. console.log(wx.env.USER_DATA_PATH + "/img.jpg");
  625. uni.saveImageToPhotosAlbum({
  626. // 保存图片到相册
  627. filePath: wx.env.USER_DATA_PATH + "/img.jpg",
  628. success: function(res) {
  629. uni.showToast({
  630. title: this.i18n.savesuccessfully,
  631. });
  632. that.imagea = false;
  633. },
  634. fail: function(err) {
  635. console.log("保存失败", err);
  636. that.imagea = false;
  637. },
  638. });
  639. },
  640. file: (err) => {
  641. console.log("写入文件失败", err);
  642. },
  643. });
  644. },
  645. // 将页面转换成图片的方法
  646. copylink() {
  647. this.$u.toast(this.i18n.window);
  648. },
  649. openfu() {
  650. this.serve = true;
  651. },
  652. returnindex() {
  653. // uni.switchTab({
  654. // url: '/pages/index/index'
  655. // })
  656. uni.navigateBack();
  657. },
  658. chat() {
  659. let useinfo = uni.getStorageSync("user_info");
  660. let that = this;
  661. let id = conn.getUniqueId(); // 生成本地消息id
  662. let msg = new WebIM.message("txt", id); // 创建文本消息
  663. msg.set({
  664. type: "txt",
  665. msg: this.i18n.merchandiseNews,
  666. to: this.goodinfo.merchant.member.easemob_username,
  667. chatType: "singleChat",
  668. ext: {
  669. type: "shopinfo",
  670. order: {
  671. name: that.name_c,
  672. image: that.goodinfo.image,
  673. discount_price: that.goodinfo.discount_price,
  674. fu: that.fu,
  675. id: that.id,
  676. },
  677. user_other: that.goodinfo.merchant,
  678. user: useinfo,
  679. },
  680. success: function(id, serverMsgId) {
  681. uni.navigateTo({
  682. url: "/pageA/chat/chat?user_other=" +
  683. encodeURIComponent(JSON.stringify(that.goodinfo.merchant)) +
  684. "&user_other_no=" +
  685. that.goodinfo.merchant.member.easemob_username,
  686. });
  687. },
  688. fail: function(e) {
  689. console.log("发送消息失败");
  690. },
  691. });
  692. conn.send(msg.body);
  693. },
  694. sharea() {
  695. this.share = true;
  696. },
  697. close() {
  698. this.show = false;
  699. this.share = false;
  700. this.serve = false;
  701. this.imagea = false;
  702. },
  703. //评论页面
  704. tocomment() {
  705. uni.navigateTo({
  706. url: "/pageA/comment?id=" + this.goodinfo.merchant_goods_id,
  707. });
  708. },
  709. //关注
  710. fllow() {
  711. uni.$u.http
  712. .post("/api/interest/follow", {
  713. interest_type: 0,
  714. interest_id: this.goodinfo.merchant_goods_id,
  715. })
  716. .then((res) => {
  717. if (res == "ok1") {
  718. this.$u.toast(this.i18n.shutdown);
  719. this.detail(this.id);
  720. } else {
  721. this.$u.toast(this.i18n.Focus);
  722. this.detail(this.id);
  723. }
  724. })
  725. .catch(() => {});
  726. },
  727. sele() {
  728. this.shopcar = 2;
  729. this.show = true;
  730. },
  731. //跳转到购物车
  732. shopping() {
  733. uni.switchTab({
  734. url: "/pages/cart/cart",
  735. });
  736. },
  737. //评论接口
  738. comment() {
  739. uni.$u.http
  740. .post("/api/goods/goods_comment", {
  741. merchant_goods_id: this.goodinfo.merchant_goods_id,
  742. page: 1,
  743. limit: 2,
  744. })
  745. .then((res) => {
  746. this.commentlist = res.data;
  747. this.total = res.total;
  748. })
  749. .catch(() => {});
  750. },
  751. //商品推荐
  752. recommend() {
  753. uni.$u.http
  754. .post("/api/goods/recommend", {
  755. keyword: "",
  756. })
  757. .then((res) => {
  758. this.swiptlist = res.reduce(
  759. (a, b) => {
  760. let lastIndex = a.length - 1;
  761. if (a[lastIndex].length < 3) {
  762. a[lastIndex].push(b);
  763. } else {
  764. a.push([b]);
  765. }
  766. return a;
  767. },
  768. [
  769. []
  770. ]
  771. );
  772. })
  773. .catch(() => {});
  774. },
  775. scrollToPosition(e) {
  776. console.log(e);
  777. var that = this;
  778. this.current = e.index;
  779. console.log(this.current);
  780. this.$nextTick(() => {
  781. that.toView = "scroll" + e.index;
  782. console.log("view", that.toView);
  783. });
  784. if (!e.index) {
  785. uni.pageScrollTo({
  786. scrollTop: 0,
  787. duration: 300,
  788. });
  789. } else if (e.index == 1 || e.index == 2) {
  790. uni
  791. .createSelectorQuery()
  792. .select(e.index == 1 ? "#scroll1" : "#scroll2")
  793. .boundingClientRect((data) => {
  794. uni
  795. .createSelectorQuery()
  796. .select(".page")
  797. .boundingClientRect((res) => {
  798. uni.pageScrollTo({
  799. duration: 100,
  800. scrollTop: data.top - res.top - 66,
  801. });
  802. })
  803. .exec();
  804. })
  805. .exec();
  806. }
  807. },
  808. //逛逛
  809. goshop(id) {
  810. uni.navigateTo({
  811. url: "/pageD/homepage/homepage?user_other=" +
  812. encodeURIComponent(JSON.stringify(this.goodinfo.merchant)) +
  813. "&user_other_no=" +
  814. this.goodinfo.merchant.member.easemob_username +
  815. "&merchant_id=" +
  816. id +
  817. "&show=" +
  818. true,
  819. });
  820. },
  821. detail(id) {
  822. uni.$u.http
  823. .get("/api/goods/detail/" + id)
  824. .then((res) => {
  825. console.log(res);
  826. this.goodinfo = res;
  827. if (this.language == "en-US") {
  828. this.name_c = this.goodinfo.name_en;
  829. }
  830. if (this.language == "es-ES") {
  831. this.name_c = this.goodinfo.name_es;
  832. }
  833. if (this.language == "it-IT") {
  834. this.name_c = this.goodinfo.name_ita;
  835. }
  836. if (this.language == "zh-CN") {
  837. this.name_c = this.goodinfo.name_cn;
  838. }
  839. this.goodinfoname = this.goodinfo.name_cn;
  840. this.goodinfoyuan = this.goodinfo.discount_price;
  841. this.comment();
  842. this.rate = res.merchant.score;
  843. })
  844. .catch(() => {});
  845. },
  846. //保障服务
  847. guarantee() {
  848. uni.$u.http
  849. .get("/api/agreement?code=guarantee_service")
  850. .then((res) => {
  851. console.log(res);
  852. this.content = res;
  853. if (this.language == "en-US") {
  854. this.fu = this.content.name_en;
  855. }
  856. if (this.language == "es-ES") {
  857. this.fu = this.content.name_es;
  858. }
  859. if (this.language == "it-IT") {
  860. this.fu = this.content.name_ita;
  861. }
  862. if (this.language == "zh-CN") {
  863. this.fu = this.content.name_cn;
  864. }
  865. })
  866. .catch(() => {});
  867. },
  868. // scrollToPosition() {
  869. // console.log(111);
  870. // // 使用$refs获取目标位置的DOM元素
  871. // const targetElement = this.$refs.targetPosition;
  872. // // 调用scrollToView方法滚动到目标位置
  873. // this.$refs.scrollView.scrollToView('targetPosition');
  874. // },
  875. actabs(index, child, idx) {
  876. console.log('index', index);
  877. console.log('child', child);
  878. console.log('idx', idx);
  879. if (this.language == "en-US") {
  880. this.childA = child.name_en
  881. }
  882. if (this.language == "es-ES") {
  883. this.childA = child.name_es
  884. }
  885. if (this.language == "it-IT") {
  886. this.childA = child.name_ita
  887. }
  888. if (this.language == "zh-CN") {
  889. this.childA = child.name
  890. }
  891. if (this.selectArr[index] != this.childA) {
  892. this.$set(this.selectArr, index, this.childA);
  893. this.$set(this.subIndex, index, idx);
  894. } else {
  895. this.$set(this.selectArr, index, "");
  896. this.$set(this.subIndex, index, -1); //去掉选中颜色
  897. }
  898. console.log('select', this.selectArr);
  899. console.log('this.selectArrindex', this.selectArr[index]);
  900. console.log('this.childA', this.childA);
  901. this.goodinfo.sku_item.forEach((ite) => {
  902. console.log('ite',ite);
  903. console.log('this.selectArr.join(",")',this.selectArr.join(","));
  904. var active = ''
  905. if (this.language == "en-US") {
  906. active = ite.item_en
  907. }
  908. if (this.language == "es-ES") {
  909. active = ite.item_es
  910. }
  911. if (this.language == "it-IT") {
  912. active = ite.item_ita
  913. }
  914. if (this.language == "zh-CN") {
  915. active = ite.item
  916. }
  917. if (active == this.selectArr.join(",")) {
  918. this.sku_info = ite;
  919. this.goodinfo.discount_price = (
  920. (Number(this.sku_info.discount_price * 100) *
  921. Number(this.value * 100)) /
  922. 10000
  923. ).toFixed(2);
  924. this.goodinfo.price = this.sku_info.price;
  925. }
  926. });
  927. console.log('2222',this.sku_info);
  928. },
  929. order() {
  930. if (JSON.stringify(this.sku_info) != "{}") {
  931. if (this.sku_info.stock_total != 0) {
  932. uni.navigateTo({
  933. url: "/pageA/order?sku=" +
  934. encodeURIComponent(JSON.stringify(this.sku_info)) +
  935. "&value=" +
  936. this.value +
  937. "&goodinfo=" +
  938. encodeURIComponent(JSON.stringify(this.goodinfo)) +
  939. "&share_merchant_id=" +
  940. this.share_merchant_id,
  941. });
  942. } else {
  943. this.$u.toast(this.i18n.understock);
  944. this.show = false;
  945. }
  946. } else {
  947. this.$u.toast(this.i18n.selection + this.i18n.specification);
  948. } // console.log(JSON.stringify(this.sku_info));
  949. },
  950. //生成图片弹窗
  951. builder() {
  952. this.imagea = true;
  953. this.share = false;
  954. },
  955. //加入购物车
  956. joincart() {
  957. if (JSON.stringify(this.sku_info) != "{}") {
  958. if (this.sku_info.stock_total == 0) {
  959. this.$u.toast(this.i18n.understock);
  960. } else {
  961. uni.$u.http
  962. .post("/api/cart/save", {
  963. goods_id: this.id, //63 是 String 商品id
  964. goods_num: this.value, //1 是 String 商品数量
  965. sku_item_id: this.sku_info.id, //38 是 String 规格详情id
  966. merchant_goods_id: this.goodinfo.merchant_goods_id, //38 是 String 团长商品id
  967. belong: this.goodinfo.source, //是 String 商品归属 0 团长 1 平台自营 2 团长发布或者分享的平台自营商品、 供应链商品
  968. share_member_id: this.share_merchant_id, //是 String 分享团长id
  969. })
  970. .then((res) => {
  971. this.$u.toast(this.i18n.successfullyAdded);
  972. this.show = false;
  973. })
  974. .catch(() => {});
  975. }
  976. } else {
  977. this.$u.toast(this.i18n.selection + this.i18n.specification);
  978. }
  979. },
  980. valChange(e) {
  981. this.goodinfo.discount_price = (
  982. (Number(this.sku_info.discount_price * 100) * Number(e.value * 100)) /
  983. 10000
  984. ).toFixed(2);
  985. return e.value;
  986. },
  987. navigateBack() {
  988. uni.navigateBack();
  989. },
  990. join(index) {
  991. this.show = true;
  992. this.shopcar = index;
  993. },
  994. //通知
  995. inform() {
  996. uni.showToast({
  997. title: this.i18n.shelves,
  998. icon: "none",
  999. duration: 2000,
  1000. });
  1001. },
  1002. //复制
  1003. onLongPress(e) {
  1004. // 获取长按的文本内容
  1005. let text = e.target.innerText;
  1006. console.log(e);
  1007. // 执行复制操作
  1008. uni.setClipboardData({
  1009. data: text,
  1010. success: () => {
  1011. uni.showToast({
  1012. title: this.i18n.Copiedpaste,
  1013. duration: 2000,
  1014. });
  1015. },
  1016. fail: () => {
  1017. uni.showToast({
  1018. title: this.i18n.Replicationfailure,
  1019. icon: "none",
  1020. duration: 2000,
  1021. });
  1022. },
  1023. });
  1024. },
  1025. },
  1026. };
  1027. </script>
  1028. <style lang="scss" scoped>
  1029. .over {
  1030. font-family: PingFangSC, PingFang SC;
  1031. font-weight: 400;
  1032. font-size: 26rpx;
  1033. color: #222222;
  1034. line-height: 36rpx;
  1035. text-align: left;
  1036. font-style: normal;
  1037. text-overflow: ellipsis;
  1038. overflow: hidden;
  1039. -webkit-line-clamp: 2;
  1040. height: 70rpx;
  1041. display: -webkit-box;
  1042. -webkit-box-orient: vertical;
  1043. word-break: break-all;
  1044. }
  1045. .redback {
  1046. background: rgba(255, 27, 0, 0.07);
  1047. border-radius: 12rpx;
  1048. padding: 6rpx 12rpx;
  1049. box-sizing: border-box;
  1050. font-family: HarmonyOS_Sans_Medium;
  1051. font-size: 16rpx;
  1052. color: #ff1515;
  1053. line-height: 22rpx;
  1054. text-align: left;
  1055. font-style: normal;
  1056. width: 150rpx;
  1057. }
  1058. .sku {
  1059. font-family: PingFangSC, PingFang SC;
  1060. font-weight: 400;
  1061. font-size: 20rpx;
  1062. color: #888888;
  1063. line-height: 28rpx;
  1064. text-align: left;
  1065. font-style: normal;
  1066. }
  1067. .acttab {
  1068. height: 68rpx;
  1069. padding: 14rpx 30rpx;
  1070. text-align: center;
  1071. box-sizing: border-box;
  1072. display: inline;
  1073. background: rgba(248, 50, 36, 0.06);
  1074. border-radius: 6rpx;
  1075. border: 2rpx solid #f83224;
  1076. font-family: PingFangSC, PingFang SC;
  1077. font-weight: 400;
  1078. font-size: 28rpx;
  1079. color: #f83224;
  1080. line-height: 40rpx;
  1081. }
  1082. .read {
  1083. font-family: HarmonyOS_Sans_Medium;
  1084. font-size: 26rpx;
  1085. color: #f83224;
  1086. line-height: 36rpx;
  1087. text-align: left;
  1088. font-style: normal;
  1089. }
  1090. // ::v-deep .u-popup__content{
  1091. // background-color: rgba(0,0,0,0) !important;
  1092. // }
  1093. .money {
  1094. font-family: HarmonyOS_Sans_Medium;
  1095. font-size: 20rpx;
  1096. color: #f83224;
  1097. line-height: 26rpx;
  1098. text-align: left;
  1099. font-style: normal;
  1100. }
  1101. .title {
  1102. font-family: PingFangSC, PingFang SC;
  1103. font-weight: 400;
  1104. font-size: 28rpx;
  1105. color: #222222;
  1106. line-height: 40rpx;
  1107. text-align: left;
  1108. font-style: normal;
  1109. margin-top: 16rpx;
  1110. width: 100%;
  1111. overflow: hidden;
  1112. text-overflow: ellipsis;
  1113. word-break: break-all;
  1114. -webkit-line-clamp: 2;
  1115. display: -webkit-box;
  1116. -webkit-box-orient: vertical;
  1117. }
  1118. .view {
  1119. font-family: PingFangSC, PingFang SC;
  1120. font-weight: 400;
  1121. font-size: 20rpx;
  1122. color: #777777;
  1123. line-height: 28rpx;
  1124. text-align: left;
  1125. font-style: normal;
  1126. margin-top: 12rpx;
  1127. }
  1128. .actabs {
  1129. width: 116rpx;
  1130. height: 68rpx;
  1131. background: rgba(248, 50, 36, 0.06);
  1132. border-radius: 6rpx;
  1133. border: 2rpx solid #f83224;
  1134. }
  1135. .bottoma {
  1136. width: 750rpx;
  1137. height: 166rpx;
  1138. background: #ffffff;
  1139. padding: 16rpx 44rpx 0;
  1140. position: fixed;
  1141. bottom: 0;
  1142. left: 0;
  1143. .btn {
  1144. width: 662rpx;
  1145. height: 84rpx;
  1146. background: #f83224;
  1147. border-radius: 44rpx;
  1148. font-family: PingFangSC, PingFang SC;
  1149. font-weight: 500;
  1150. font-size: 32rpx;
  1151. color: #ffffff;
  1152. line-height: 84rpx;
  1153. text-align: center;
  1154. font-style: normal;
  1155. }
  1156. }
  1157. .title1 {
  1158. font-family: PingFangSC, PingFang SC;
  1159. font-weight: 550;
  1160. font-size: 32rpx;
  1161. color: #222222;
  1162. line-height: 44rpx;
  1163. text-align: left;
  1164. font-style: normal;
  1165. }
  1166. .tabs {
  1167. // width: 276rpx;
  1168. height: 68rpx;
  1169. padding: 14rpx 30rpx;
  1170. text-align: center;
  1171. background: #f4f4f4;
  1172. border-radius: 6rpx;
  1173. box-sizing: border-box;
  1174. display: inline;
  1175. font-size: 28rpx;
  1176. border: 2rpx solid rgba(151, 151, 151, 0);
  1177. line-height: 40rpx;
  1178. // line-height: 68rpx;
  1179. }
  1180. .link {
  1181. font-family: PingFangSC, PingFang SC;
  1182. font-weight: 400;
  1183. font-size: 28rpx;
  1184. color: #555555;
  1185. line-height: 40rpx;
  1186. text-align: left;
  1187. font-style: normal;
  1188. margin-top: 16rpx;
  1189. }
  1190. .tongzhi {
  1191. width: 422rpx;
  1192. height: 76rpx;
  1193. background: #ffb515;
  1194. border-radius: 40rpx;
  1195. font-family: PingFangSC, PingFang SC;
  1196. font-weight: 500;
  1197. font-size: 28rpx;
  1198. color: #ffffff;
  1199. line-height: 76rpx;
  1200. text-align: center;
  1201. font-style: normal;
  1202. }
  1203. .info {
  1204. font-family: PingFangSC, PingFang SC;
  1205. font-weight: 400;
  1206. font-size: 20rpx;
  1207. color: #222222;
  1208. line-height: 28rpx;
  1209. text-align: left;
  1210. font-style: normal;
  1211. margin-top: 18rpx;
  1212. }
  1213. .button {
  1214. // width: 662rpx;
  1215. height: 88rpx;
  1216. background: #f83224;
  1217. border-radius: 44rpx;
  1218. margin-top: 24rpx;
  1219. font-family: PingFangSC, PingFang SC;
  1220. font-weight: 500;
  1221. font-size: 32rpx;
  1222. color: #ffffff;
  1223. line-height: 88rpx;
  1224. text-align: center;
  1225. font-style: normal;
  1226. }
  1227. .contenta {
  1228. width: 702rpx;
  1229. // height: 590rpx;
  1230. background: #ffffff;
  1231. border-radius: 20rpx;
  1232. margin-top: 26rpx;
  1233. padding: 28rpx 24rpx;
  1234. box-sizing: border-box;
  1235. .title {
  1236. font-family: PingFangSC, PingFang SC;
  1237. font-weight: 500;
  1238. font-size: 30rpx;
  1239. color: #222222;
  1240. line-height: 42rpx;
  1241. text-align: left;
  1242. font-style: normal;
  1243. }
  1244. .content {
  1245. font-family: PingFangSC, PingFang SC;
  1246. font-weight: 400;
  1247. font-size: 26rpx;
  1248. color: rgba(34, 34, 34, 0.5);
  1249. line-height: 36rpx;
  1250. text-align: left;
  1251. font-style: normal;
  1252. margin-top: 20rpx;
  1253. }
  1254. }
  1255. .back {
  1256. background-color: #f4f4f4;
  1257. padding: 20rpx;
  1258. box-sizing: border-box;
  1259. .guige {}
  1260. .fix {
  1261. width: 750rpx;
  1262. height: 158rpx;
  1263. background: #ffffff;
  1264. padding: 14rpx 28rpx;
  1265. box-sizing: border-box;
  1266. position: fixed;
  1267. bottom: 0;
  1268. left: 0;
  1269. .ke {
  1270. font-family: PingFangSC, PingFang SC;
  1271. font-weight: 400;
  1272. font-size: 20rpx;
  1273. color: #333333;
  1274. line-height: 28rpx;
  1275. text-align: left;
  1276. font-style: normal;
  1277. }
  1278. .join {
  1279. width: 208rpx;
  1280. height: 76rpx;
  1281. border-radius: 40rpx;
  1282. border: 1rpx solid #ff1515;
  1283. font-family: PingFangSC, PingFang SC;
  1284. font-weight: 500;
  1285. font-size: 28rpx;
  1286. color: #f83224;
  1287. line-height: 76rpx;
  1288. text-align: left;
  1289. font-style: normal;
  1290. text-align: center;
  1291. }
  1292. .pin {
  1293. width: 208rpx;
  1294. height: 76rpx;
  1295. background: #f83224;
  1296. border-radius: 40rpx;
  1297. font-family: PingFangSC, PingFang SC;
  1298. font-weight: 500;
  1299. font-size: 28rpx;
  1300. color: #ffffff;
  1301. line-height: 76rpx;
  1302. text-align: center;
  1303. font-style: normal;
  1304. }
  1305. }
  1306. // 规格
  1307. .specification {
  1308. width: 670rpx;
  1309. // height: 280rpx;
  1310. background: #f4f4f4;
  1311. padding: 24rpx 22rpx;
  1312. box-sizing: border-box;
  1313. view:last-of-type {
  1314. margin-bottom: 0rpx !important;
  1315. }
  1316. .item {
  1317. font-family: PingFangSC, PingFang SC;
  1318. font-weight: 400;
  1319. font-size: 26rpx;
  1320. color: #333333;
  1321. line-height: 36rpx;
  1322. text-align: left;
  1323. font-style: normal;
  1324. }
  1325. }
  1326. // 推荐
  1327. .recommend {
  1328. width: 710rpx;
  1329. // height: 476rpx;
  1330. background: #ffffff;
  1331. border-radius: 16rpx;
  1332. padding: 24rpx 20rpx;
  1333. margin-top: 20rpx;
  1334. box-sizing: border-box;
  1335. .title {
  1336. font-family: PingFangSC, PingFang SC;
  1337. font-weight: 550;
  1338. font-size: 28rpx;
  1339. color: #222222;
  1340. line-height: 40rpx;
  1341. text-align: left;
  1342. font-style: normal;
  1343. }
  1344. }
  1345. //店铺
  1346. .store {
  1347. width: 710rpx;
  1348. height: 160rpx;
  1349. background: #ffffff;
  1350. border-radius: 16rpx;
  1351. padding: 24rpx 20rpx;
  1352. box-sizing: border-box;
  1353. margin-top: 20rpx;
  1354. .line {
  1355. background: rgba(151, 151, 151, 1);
  1356. width: 4rpx;
  1357. height: 20rpx;
  1358. margin: 0 18rpx;
  1359. }
  1360. .num {
  1361. font-family: SFPro, SFPro;
  1362. font-weight: 400;
  1363. font-size: 20rpx;
  1364. color: #777777;
  1365. line-height: 24rpx;
  1366. text-align: left;
  1367. font-style: normal;
  1368. }
  1369. .goshop {
  1370. // width: 108rpx;
  1371. height: 52rpx;
  1372. border-radius: 26rpx;
  1373. border: 1rpx solid #ff1515;
  1374. font-family: PingFangSC, PingFang SC;
  1375. font-weight: 400;
  1376. font-size: 24rpx;
  1377. color: #f83224;
  1378. line-height: 52rpx;
  1379. text-align: center;
  1380. font-style: normal;
  1381. padding: 0 20rpx;
  1382. box-sizing: border-box;
  1383. }
  1384. }
  1385. // 评论
  1386. .comment {
  1387. width: 710rpx;
  1388. // height: 356rpx;
  1389. background: #ffffff;
  1390. border-radius: 16rpx;
  1391. margin-top: 20rpx;
  1392. padding: 24rpx 20rpx;
  1393. box-sizing: border-box;
  1394. .content {
  1395. margin-top: 20rpx;
  1396. font-family: PingFangSC, PingFang SC;
  1397. font-weight: 400;
  1398. font-size: 26rpx;
  1399. color: #444444;
  1400. line-height: 36rpx;
  1401. text-align: left;
  1402. font-style: normal;
  1403. max-height: 112rpx;
  1404. overflow: hidden;
  1405. text-overflow: ellipsis;
  1406. white-space: wrap;
  1407. -webkit-line-clamp: 3;
  1408. word-break: break-all;
  1409. }
  1410. .name {
  1411. font-family: PingFangSC, PingFang SC;
  1412. font-weight: 400;
  1413. font-size: 24rpx;
  1414. color: #222222;
  1415. line-height: 34rpx;
  1416. text-align: left;
  1417. font-style: normal;
  1418. margin-left: 16rpx;
  1419. }
  1420. .ping {
  1421. font-family: PingFangSC, PingFang SC;
  1422. font-weight: 500;
  1423. font-size: 28rpx;
  1424. color: #222222;
  1425. line-height: 40rpx;
  1426. text-align: left;
  1427. font-style: normal;
  1428. }
  1429. .strip {
  1430. font-family: PingFangSC, PingFang SC;
  1431. font-weight: 400;
  1432. font-size: 24rpx;
  1433. color: #444444;
  1434. line-height: 34rpx;
  1435. text-align: left;
  1436. font-style: normal;
  1437. }
  1438. }
  1439. //服务
  1440. .serve {
  1441. width: 710rpx;
  1442. // height: 180rpx;
  1443. background: #ffffff;
  1444. border-radius: 16rpx;
  1445. padding: 32rpx 20rpx;
  1446. box-sizing: border-box;
  1447. .top {
  1448. .change {
  1449. font-family: PingFangSC, PingFang SC;
  1450. font-weight: 400;
  1451. font-size: 28rpx;
  1452. color: #666666;
  1453. line-height: 40rpx;
  1454. text-align: left;
  1455. font-style: normal;
  1456. }
  1457. }
  1458. }
  1459. //折扣
  1460. .discount {
  1461. position: relative;
  1462. height: 312rpx;
  1463. .top {
  1464. width: 710rpx;
  1465. height: 124rpx;
  1466. background: linear-gradient(295deg, #fb6662 0%, #fd403b 100%);
  1467. border-radius: 16rpx 16rpx 0 0;
  1468. padding: 20rpx;
  1469. box-sizing: border-box;
  1470. line-height: 98rpx;
  1471. .count {
  1472. font-family: PingFangSC, PingFang SC;
  1473. font-weight: 400;
  1474. font-size: 20rpx;
  1475. color: #ffffff;
  1476. text-align: left;
  1477. font-style: normal;
  1478. }
  1479. .money {
  1480. font-size: 20rpx;
  1481. font-family: HarmonyOS_Sans_Medium;
  1482. font-size: 20rpx;
  1483. color: #ffffff;
  1484. text-align: left;
  1485. font-style: normal;
  1486. margin-left: 8rpx;
  1487. }
  1488. .right {
  1489. font-family: HarmonyOS_Sans;
  1490. font-size: 24rpx;
  1491. color: #ffffff;
  1492. text-align: left;
  1493. font-style: normal;
  1494. text-decoration-line: line-through;
  1495. margin-left: 16rpx;
  1496. }
  1497. }
  1498. .bottom {
  1499. width: 710rpx;
  1500. height: 208rpx;
  1501. background: #ffffff;
  1502. border-radius: 16rpx;
  1503. position: absolute;
  1504. top: 104rpx;
  1505. z-index: 2;
  1506. padding: 28rpx 20rpx;
  1507. box-sizing: border-box;
  1508. .title {
  1509. margin-top: 24rpx;
  1510. font-family: PingFangSC, PingFang SC;
  1511. font-weight: 550;
  1512. font-size: 32rpx;
  1513. color: #222222;
  1514. line-height: 44rpx;
  1515. text-align: left;
  1516. font-style: normal;
  1517. }
  1518. }
  1519. .tabs {
  1520. // width: 104rpx;
  1521. height: 40rpx;
  1522. background: rgba(255, 21, 21, 0.1);
  1523. border-radius: 4rpx;
  1524. padding: 4rpx 8rpx;
  1525. font-family: PingFangSC, PingFang SC;
  1526. font-weight: 400;
  1527. font-size: 22rpx;
  1528. color: #ff1515;
  1529. line-height: 40rpx;
  1530. text-align: center;
  1531. font-style: normal;
  1532. }
  1533. }
  1534. }
  1535. // 轮播图
  1536. .uni-margin-wrap {
  1537. width: 750rpx;
  1538. width: 100%;
  1539. .swiper {
  1540. height: 750rpx;
  1541. }
  1542. .swiper-item {
  1543. display: block;
  1544. height: 300rpx;
  1545. line-height: 300rpx;
  1546. text-align: center;
  1547. }
  1548. .swiper-list {
  1549. margin-top: 40rpx;
  1550. margin-bottom: 0;
  1551. }
  1552. .uni-common-mt {
  1553. margin-top: 60rpx;
  1554. position: relative;
  1555. }
  1556. .info {
  1557. position: absolute;
  1558. right: 20rpx;
  1559. }
  1560. .uni-padding-wrap {
  1561. width: 550rpx;
  1562. padding: 0 100rpx;
  1563. }
  1564. }
  1565. ::v-deep .u-popup__content data-v-17becaea {
  1566. align-items: center !important;
  1567. }
  1568. </style>