cart.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805
  1. <template>
  2. <!-- 购物车 -->
  3. <view class="page" @click="num = ''">
  4. <u-navbar :safeAreaInsetTop="true" :placeholder="true">
  5. <view class="u-nav-slot" slot="left">
  6. <view class="">
  7. <text class="shopcart">{{ i18n.Shopping }}</text>
  8. <text class="sum">({{ goodsNum }})</text>
  9. </view>
  10. </view>
  11. <view class="u-nav-slot" slot="right">
  12. <view class="u-flex">
  13. <text @click="admin" v-if="success">{{ i18n.manage }}</text>
  14. <text @click="admin" v-else>{{ i18n.complete }}</text>
  15. <view class="" style="width: 200rpx"></view>
  16. </view>
  17. </view>
  18. </u-navbar>
  19. <u-checkbox-group v-model="checkboxValue1" placement="column" @change="checkboxChange">
  20. <view class="box" v-for="(item, idx) in goodsList" :key="idx">
  21. <view class="item">
  22. <view class="shopname u-flex">
  23. <image src="/static/mine/354.png" class="circle" mode="scaleToFill"
  24. @click="shopSelectAll(item.goods)" v-if="shop(item.goods)" />
  25. <image src="/static/mine/353.png" class="circle" mode="scaleToFill"
  26. @click="shopSelectAll(item.goods)" v-else />
  27. <image :src="item.image" style="width: 28rpx; height: 28rpx" mode=""></image>
  28. <text>{{ item.merchant_name }}</text>
  29. <image src="/static/express/next1.png" style="width: 32rpx; height: 32rpx" mode=""></image>
  30. </view>
  31. <u-swipe-action>
  32. <view class="u-flex" style="margin-top: 30rpx; width: 100%" v-for="(chid, index) in item.goods"
  33. :key="index">
  34. <u-swipe-action-item ref="show" :options="options2" @click="followOrdelete"
  35. :autoClose="true" :name="chid.cart.id" :disabled="chid.status == 'down'">
  36. <!-- <view class="" style="position: absolute;top: 0;left: 0;width: 100%;height: 100%;z-index: 100;background-color: rgba(255, 255, 255, 0.5);"></view> -->
  37. <u-checkbox shape="circle" :customStyle="{ marginBottom: '8px' }" :name="chid.cart.id"
  38. activeColor="#F83224" :disabled="chid.status == 'down'">
  39. </u-checkbox>
  40. <view class="" style="
  41. position: relative;
  42. width: 172rpx;
  43. height: 172rpx;
  44. border-radius: 16rpx;
  45. ">
  46. <image :src="chid.image" style="width: 172rpx; height: 172rpx; border-radius: 20rpx"
  47. mode="">
  48. </image>
  49. <view class="down" v-if="chid.status == 'down'">
  50. <view class="sold"> 商品下架 </view>
  51. </view>
  52. </view>
  53. <view class="good" style="flex: 1; margin-left: 10rpx; width: 65%">
  54. <view class="goodname">{{ chid.name_cn }}</view>
  55. <view class="goods" v-if="chid.sku_item.length > 0">{{
  56. chid.sku_item[0].item
  57. }}</view>
  58. <view class="" style="margin-top: 21rpx">
  59. <view class="goodtab" v-for="itemLabel in chid.label_arr" :key="itemLabel.id">
  60. {{ itemLabel.name_cn }}
  61. </view>
  62. </view>
  63. <view class="u-flex u-row-between" style="width: 100%; margin-top: 20rpx">
  64. <view class="" v-if="chid.sku_item.length > 0">
  65. <text class="money">¥</text>
  66. <text class="money" style="font-size: 30rpx">{{
  67. chid.sku_item[0].discount_price.split(".")[0]
  68. }}</text>
  69. <text
  70. class="money">.{{ chid.sku_item[0].discount_price.split(".")[1] }}</text>
  71. <text class="weight">{{ chid.sku_item[0].weight }}kg</text>
  72. </view>
  73. <view class="aaaaaa">
  74. <!-- <view class="delect" v-if='dele'>{{i18n.delete}}</view> -->
  75. <view class="" v-if="num == chid.cart.id && success">
  76. <!-- <u-number-box v-model="value" @change="valChange"></u-number-box> -->
  77. <u-number-box v-model="chid.cart.goods_num" @change="addOrReduce">
  78. <view slot="minus" class="minus">
  79. <u-icon name="minus" color="#B5B5B5" size="12"></u-icon>
  80. </view>
  81. <text slot="input" style="
  82. width: 50px;
  83. text-align: center;
  84. font-size: 20rpx;
  85. " class="input">{{ chid.cart.goods_num }}</text>
  86. <view slot="plus" class="plus">
  87. <u-icon name="plus" color="#B5B5B5" size="12"></u-icon>
  88. </view>
  89. </u-number-box>
  90. </view>
  91. <view class="num" v-if="
  92. num != chid.cart.id &&
  93. success &&
  94. chid.status == 'normal'
  95. " @click.stop="num = chid.cart.id">
  96. x{{ chid.cart.goods_num }}
  97. </view>
  98. <view v-if="success && chid.status == 'down'" class="del" @click="
  99. followOrdelete({
  100. index: 1,
  101. name: chid.cart.id,
  102. })
  103. ">删除</view>
  104. </view>
  105. <view v-if="success == false" class="icon delete-1" @click="
  106. followOrdelete({
  107. index: 1,
  108. name: chid.cart.id,
  109. })
  110. ">
  111. <u-icon name="trash" color="#fff" size="20"></u-icon>
  112. </view>
  113. </view>
  114. </view>
  115. </u-swipe-action-item>
  116. </view>
  117. </u-swipe-action>
  118. </view>
  119. </view>
  120. </u-checkbox-group>
  121. <u-toast ref="uToast"></u-toast>
  122. <view class="" style="height: 260rpx"></view>
  123. <view class="back-top" @click="backTop">
  124. <image class="back-icon" src="../../static/mine/355.png" mode="scaleToFill" />
  125. <text class="back-text">顶部</text>
  126. </view>
  127. <kj-tabbar ref="tabbar1" :value1="3" :success="success" @allSelect="allSelect" :goodsWeight="goodsWeight"
  128. :goodsPrice="String(goodsPrice.toFixed(2))" :goodsList="goodsList" :checkboxValue1="checkboxValue1"
  129. @selectDelete="selectDelete"></kj-tabbar>
  130. </view>
  131. </template>
  132. <script>
  133. export default {
  134. data() {
  135. return {
  136. dele: true,
  137. success: true,
  138. shopitem: -1,
  139. checkboxValue1: [], //商品数组
  140. value: 0,
  141. all: [], //全选数组
  142. goodsList: [],
  143. selectall: -1,
  144. goodsNum: 0, //购物车商品数量
  145. num: false,
  146. goodsWeight: 0, //商品重量
  147. goodsPrice: 0, //商品价格
  148. options2: [{
  149. text: "移入关注",
  150. style: {
  151. backgroundColor: "#FFB115",
  152. },
  153. },
  154. {
  155. text: "删除",
  156. style: {
  157. backgroundColor: "#F83224",
  158. },
  159. },
  160. ],
  161. tabarheight: "",
  162. removeProducts: 0, //已下架的商品数量
  163. };
  164. },
  165. watch: {},
  166. computed: {
  167. i18n() {
  168. return this.$t("index");
  169. },
  170. },
  171. onLoad() {
  172. const systemInfo = wx.getSystemInfoSync();
  173. const tab =
  174. systemInfo.screenHeight -
  175. systemInfo.safeArea.bottom +
  176. systemInfo.statusBarHeight;
  177. this.tabarheight = tab;
  178. },
  179. onShow() {
  180. this.getShopCarList();
  181. },
  182. methods: {
  183. //返回顶部
  184. backTop() {
  185. uni.pageScrollTo({
  186. scrollTop: 0, // 滚动到页面的目标位置 这个是滚动到顶部, 0
  187. duration: 300, // 滚动动画的时长
  188. });
  189. },
  190. //商品下架之后的商品字体颜色
  191. getFontColor(status) {
  192. if (status == "down") {
  193. return "color:rgba(51, 51, 51, .6)";
  194. }
  195. },
  196. //关注商品 or 删除商品
  197. followOrdelete(e) {
  198. //关注商品
  199. if (e.index == 0) {
  200. this.goodsList.map((item) => {
  201. item.goods.map((items) => {
  202. if (e.name == items.cart.id) {
  203. console.log(items);
  204. uni.$u.http
  205. .post(`/api/interest/follow`, {
  206. interest_type: 0,
  207. interest_id: items.merchant_goods.id,
  208. })
  209. .then((res) => {
  210. this.$refs.show.forEach((item) => item.closeHandler(true));
  211. console.log(res);
  212. uni.showToast({
  213. title: "关注成功",
  214. icon: "none",
  215. });
  216. });
  217. }
  218. });
  219. });
  220. } else {
  221. //删除商品
  222. this.goodsList.map((item) => {
  223. item.goods.map((items) => {
  224. if (e.name == items.cart.id) {
  225. uni.$u.http
  226. .delete(`/api/cart?ids=${items.cart.id}`)
  227. .then((res) => {
  228. this.$refs.uToast.show({
  229. type: "default",
  230. title: "默认主题",
  231. message: "删除成功",
  232. });
  233. //删除后关闭滑动打开的单元格
  234. this.$refs.show.forEach((item) => item.closeHandler(true));
  235. this.getShopCarList();
  236. });
  237. }
  238. });
  239. });
  240. }
  241. },
  242. //多选删除
  243. selectDelete() {
  244. let goodsIdList = []; //筛选选中的商品id
  245. this.goodsList.map((item) => {
  246. item.goods.map((items) => {
  247. if (this.checkboxValue1.indexOf(items.cart.id) >= 0) {
  248. goodsIdList.push(items.cart.id);
  249. }
  250. });
  251. });
  252. uni.$u.http
  253. .delete(`/api/cart`, {
  254. ids: goodsIdList.join(",")
  255. })
  256. .then((res) => {
  257. this.$refs.uToast.show({
  258. type: "default",
  259. title: "默认主题",
  260. message: "删除成功",
  261. });
  262. this.checkboxValue1 = [];
  263. this.getShopCarList();
  264. });
  265. },
  266. shop(value) {
  267. let num = 0;
  268. value.map((item) => {
  269. if (this.checkboxValue1.indexOf(item.cart.id) >= 0) {
  270. num++;
  271. }
  272. });
  273. return num;
  274. },
  275. //获取排除下架的商品之后的商品数量
  276. getNormalGoodsNum(value) {
  277. let num = 0;
  278. value.map((item) => {
  279. if (item.status != "down") {
  280. num++;
  281. }
  282. });
  283. return num;
  284. },
  285. //修改购物车商品数量
  286. addOrReduce(n) {
  287. console.log(n);
  288. uni.$u.http
  289. .post(`/api/cart/num/${this.num}`, {
  290. goods_num: n.value,
  291. type: "",
  292. })
  293. .then((res) => {
  294. this.goodsPrice = 0;
  295. this.goodsWeight = 0;
  296. this.goodsList.map((item) => {
  297. item.goods.map((items) => {
  298. //判断是否有商品已被选中
  299. if (
  300. this.checkboxValue1.indexOf(items.cart.id) != -1 &&
  301. items.status != "down"
  302. ) {
  303. this.goodsWeight +=
  304. items.sku_item[0].weight * items.cart.goods_num;
  305. this.goodsPrice +=
  306. Number(items.sku_item[0].discount_price) * items.cart
  307. .goods_num;
  308. }
  309. });
  310. });
  311. });
  312. },
  313. //店铺商品全选
  314. shopSelectAll(value) {
  315. this.goodsPrice = 0;
  316. this.goodsWeight = 0;
  317. //先判断存放选中的数组有没有选中的数据
  318. if (this.checkboxValue1.length == 0) {
  319. //没有数据则直接将选中店铺中的商品存入数组
  320. value.map((item) => {
  321. //商品下架不得选中
  322. if (item.status != "down") {
  323. this.checkboxValue1.push(item.cart.id);
  324. }
  325. });
  326. } else {
  327. if (
  328. this.shop(value) > 0 &&
  329. this.shop(value) == this.getNormalGoodsNum(value)
  330. ) {
  331. value.map((item) => {
  332. //先判断选中的商品数组中该店铺商品是否已被选中,已被选中则取消选中
  333. if (this.checkboxValue1.indexOf(item.cart.id) >= 0) {
  334. this.checkboxValue1.splice(
  335. this.checkboxValue1.indexOf(item.cart.id),
  336. 1
  337. );
  338. }
  339. });
  340. } else if (
  341. (this.shop(value) > 0 &&
  342. this.shop(value) != this.getNormalGoodsNum(value)) ||
  343. this.shop(value) == 0
  344. ) {
  345. value.map((item) => {
  346. //先判断选中的商品数组中该店铺商品是否已被选中,未被选中则推入选中状态,商品下架不得选中
  347. if (
  348. this.checkboxValue1.indexOf(item.cart.id) == -1 &&
  349. item.status != "down"
  350. ) {
  351. this.checkboxValue1.push(item.cart.id);
  352. }
  353. });
  354. }
  355. }
  356. if (this.checkboxValue1.length == this.goodsNum - this.removeProducts) {
  357. this.$refs.tabbar1.cancelAll();
  358. } else {
  359. this.$refs.tabbar1.cancelAll("取消");
  360. }
  361. //将选中的商品价格相加
  362. this.goodsList.map((item) => {
  363. item.goods.map((items) => {
  364. if (this.checkboxValue1.indexOf(items.cart.id) > -1) {
  365. this.goodsWeight += items.sku_item[0].weight * items.cart.goods_num;
  366. this.goodsPrice +=
  367. Number(items.sku_item[0].discount_price) * items.cart.goods_num;
  368. }
  369. });
  370. });
  371. this.shop(value);
  372. },
  373. admin() {
  374. console.log(this.checkboxValue1);
  375. this.success = !this.success;
  376. },
  377. valChange(e) {
  378. console.log("当前值为: " + e.value);
  379. },
  380. //全选
  381. checkAll(e) {
  382. console.log("all", e);
  383. },
  384. //购物车单选
  385. checkboxChange(n) {
  386. console.log(n);
  387. //首先将价格和商品重量重置
  388. this.goodsWeight = 0;
  389. this.goodsPrice = 0;
  390. this.checkboxValue1 = n;
  391. this.goodsList.map((item) => {
  392. item.goods.map((items) => {
  393. if (n.indexOf(items.cart.id) > -1) {
  394. this.goodsWeight += items.sku_item[0].weight * items.cart.goods_num;
  395. this.goodsPrice +=
  396. Number(items.sku_item[0].discount_price) * items.cart.goods_num;
  397. }
  398. });
  399. });
  400. //判断是否全部选中
  401. if (
  402. this.checkboxValue1.length == this.goodsNum - this.removeProducts &&
  403. this.goodsNum != 0
  404. ) {
  405. this.$refs.tabbar1.cancelAll();
  406. } else if (
  407. this.checkboxValue1.length <
  408. this.goodsNum - this.removeProducts
  409. ) {
  410. this.$refs.tabbar1.cancelAll("取消");
  411. }
  412. },
  413. //购物车全选
  414. allSelect() {
  415. const all = this.$refs.tabbar1.cancelAll("全选");
  416. if (
  417. this.checkboxValue1.length == this.goodsNum - this.removeProducts &&
  418. all.length == 0
  419. ) {
  420. return;
  421. }
  422. //判断是否已经全选,如已全选,则取消全选
  423. if (this.checkboxValue1.length == this.goodsNum - this.removeProducts) {
  424. this.checkboxValue1 = [];
  425. this.goodsPrice = 0;
  426. this.goodsWeight = 0;
  427. } else {
  428. this.goodsList.map((item) => {
  429. item.goods.map((items) => {
  430. //判断是否有商品已被选中
  431. if (
  432. this.checkboxValue1.indexOf(items.cart.id) == -1 &&
  433. items.status != "down"
  434. ) {
  435. this.checkboxValue1.push(items.cart.id);
  436. this.goodsWeight +=
  437. items.sku_item[0].weight * items.cart.goods_num;
  438. this.goodsPrice +=
  439. Number(items.sku_item[0].discount_price) * items.cart.goods_num;
  440. }
  441. });
  442. });
  443. }
  444. },
  445. //获取购物车数据
  446. getShopCarList() {
  447. this.goodsNum = 0;
  448. uni.$u.http.get(`/api/cart`).then((res) => {
  449. this.goodsList = res.data;
  450. //循环店铺,获取购物车商品数量
  451. this.goodsList.map((item) => {
  452. this.goodsNum += item.goods.length;
  453. item.goods.map((items) => {
  454. if (items.status == "down") {
  455. this.removeProducts++;
  456. }
  457. });
  458. });
  459. });
  460. },
  461. },
  462. // mounted() {
  463. // this.getShopCarList();
  464. // },
  465. };
  466. </script>
  467. <style lang="scss" scoped>
  468. .page {
  469. position: relative;
  470. .back-top {
  471. position: fixed;
  472. display: flex;
  473. flex-direction: column;
  474. justify-content: center;
  475. align-items: center;
  476. width: 88rpx;
  477. height: 88rpx;
  478. background-color: #fff;
  479. border-radius: 50%;
  480. bottom: 280rpx;
  481. right: 20rpx;
  482. z-index: 1000;
  483. .back-icon {
  484. width: 32rpx;
  485. height: 30rpx;
  486. }
  487. .back-text {
  488. font-size: 20rpx;
  489. color: #555;
  490. }
  491. }
  492. }
  493. .sold {
  494. width: 108rpx;
  495. height: 36rpx;
  496. background: rgba(0, 0, 0, 0.4);
  497. border-radius: 18rpx;
  498. // padding: 0 14rpx;
  499. text-align: center;
  500. box-sizing: border-box;
  501. line-height: 36rpx;
  502. font-family: PingFangSC, PingFang SC;
  503. font-weight: 400;
  504. font-size: 20rpx;
  505. color: #ffffff;
  506. font-style: normal;
  507. position: absolute;
  508. top: 50%;
  509. left: 50%;
  510. margin-top: -18rpx;
  511. margin-left: -54rpx;
  512. }
  513. .delect {
  514. // width: 68rpx;
  515. height: 44rpx;
  516. line-height: 44rpx;
  517. border-radius: 22rpx;
  518. border: 1rpx solid #ff1515;
  519. padding: 0 14rpx;
  520. box-sizing: border-box;
  521. font-family: PingFangSC, PingFang SC;
  522. font-weight: 400;
  523. font-size: 20rpx;
  524. color: #ff1515;
  525. text-align: center;
  526. font-style: normal;
  527. }
  528. .allweight {
  529. font-family: PingFangSC, PingFang SC;
  530. font-weight: 400;
  531. font-size: 22rpx;
  532. color: #333333;
  533. line-height: 32rpx;
  534. text-align: left;
  535. font-style: normal;
  536. }
  537. .sum {
  538. font-family: PingFangSC, PingFang SC;
  539. font-weight: 400;
  540. font-size: 22rpx;
  541. color: #333333;
  542. line-height: 32rpx;
  543. text-align: left;
  544. font-style: normal;
  545. }
  546. .summon {
  547. font-family: JDZhengHT, JDZhengHT;
  548. font-weight: 400;
  549. font-size: 24rpx;
  550. color: #ff1515;
  551. line-height: 30rpx;
  552. text-align: left;
  553. font-style: normal;
  554. }
  555. .settle {
  556. width: 176rpx;
  557. height: 68rpx;
  558. background: #f83224;
  559. border-radius: 38rpx;
  560. font-family: PingFangSC, PingFang SC;
  561. font-weight: 500;
  562. font-size: 28rpx;
  563. color: #ffffff;
  564. line-height: 68rpx;
  565. text-align: center;
  566. font-style: normal;
  567. margin-left: 20rpx;
  568. }
  569. .icon {
  570. width: 40rpx;
  571. height: 40rpx;
  572. background: #f83224;
  573. border-radius: 12rpx;
  574. display: flex;
  575. justify-content: center;
  576. align-items: center;
  577. }
  578. .dle {
  579. width: 136rpx;
  580. height: 60rpx;
  581. border-radius: 38rpx;
  582. border: 1rpx solid #979797;
  583. font-family: PingFangSC, PingFang SC;
  584. font-weight: 400;
  585. font-size: 26rpx;
  586. color: #333333;
  587. line-height: 60rpx;
  588. text-align: center;
  589. font-style: normal;
  590. }
  591. ::v-deep .u-swipe-action-item__content {
  592. flex-direction: row !important;
  593. }
  594. ::v-deep .u-swipe-action-item__right__button__wrapper {
  595. width: 32px;
  596. word-wrap: break-word;
  597. font-size: 20rpx !important;
  598. }
  599. ::v-deep .u-swipe-action-item__right__button__wrapper__text {
  600. word-wrap: break-word;
  601. }
  602. ::v-deep .u-swipe-action-item {
  603. width: 100% !important;
  604. }
  605. ::v-deep .u-swipe-action-item__right {
  606. top: 2rpx !important;
  607. right: 2rpx !important;
  608. bottom: 2rpx !important;
  609. }
  610. .bottom {
  611. width: 750rpx;
  612. height: 100rpx;
  613. background: #ffffff;
  614. padding: 0 24rpx;
  615. box-sizing: border-box;
  616. }
  617. .num {
  618. width: 40rpx;
  619. height: 40rpx;
  620. border-radius: 20rpx;
  621. border: 1rpx solid rgba(151, 151, 151, 0.4);
  622. font-family: HarmonyOS_Sans;
  623. font-size: 20rpx;
  624. color: #222222;
  625. line-height: 40rpx;
  626. text-align: center;
  627. font-style: normal;
  628. }
  629. .del {
  630. width: 68rpx;
  631. height: 44rpx;
  632. text-align: center;
  633. line-height: 44rpx;
  634. border: 2rpx solid #f83224;
  635. color: #f83224;
  636. font-size: 20rpx;
  637. border-radius: 22rpx;
  638. }
  639. .box {
  640. padding: 0rpx 24rpx 20rpx;
  641. margin-top: 20rpx;
  642. box-sizing: border-box;
  643. .item {
  644. padding: 36rpx 20rpx;
  645. box-sizing: border-box;
  646. width: 702rpx;
  647. // height: 556rpx;
  648. background: #ffffff;
  649. border-radius: 16rpx;
  650. .money {
  651. font-family: HarmonyOS_Sans_Medium;
  652. font-size: 20rpx;
  653. color: #ff1515;
  654. line-height: 26rpx;
  655. text-align: left;
  656. font-style: normal;
  657. }
  658. .weight {
  659. font-family: SFPro, SFPro;
  660. font-weight: 400;
  661. font-size: 20rpx;
  662. color: #333333;
  663. line-height: 24rpx;
  664. text-align: left;
  665. font-style: normal;
  666. margin-left: 12rpx;
  667. }
  668. .goodtab {
  669. // width: 96rpx;
  670. height: 32rpx;
  671. border-radius: 4rpx;
  672. border: 1rpx solid #ff1515;
  673. padding: 2rpx 8rpx;
  674. box-sizing: border-box;
  675. text-align: center;
  676. line-height: 32rpx;
  677. display: inline;
  678. font-family: PingFangSC, PingFang SC;
  679. font-weight: 400;
  680. font-size: 20rpx;
  681. color: #ff1515;
  682. line-height: 28rpx;
  683. text-align: left;
  684. font-style: normal;
  685. margin-right: 6rpx;
  686. }
  687. .goods {
  688. // width: 284rpx;
  689. height: 40rpx;
  690. background: #f4f4f4;
  691. border-radius: 8rpx;
  692. display: inline;
  693. text-align: center;
  694. line-height: 40rpx;
  695. margin-top: 20rpx;
  696. padding: 6rpx 12rpx;
  697. box-sizing: border-box;
  698. font-family: PingFangSC, PingFang SC;
  699. font-weight: 400;
  700. font-size: 20rpx;
  701. color: #555555;
  702. line-height: 28rpx;
  703. text-align: left;
  704. font-style: normal;
  705. }
  706. .goodname {
  707. font-family: PingFangSC, PingFang SC;
  708. font-weight: 500;
  709. font-size: 28rpx;
  710. color: #333333;
  711. line-height: 40rpx;
  712. text-align: left;
  713. font-style: normal;
  714. overflow: hidden;
  715. text-overflow: ellipsis;
  716. word-break: break-all;
  717. white-space: nowrap;
  718. width: 100%;
  719. }
  720. .shopname {
  721. font-family: PingFangSC, PingFang SC;
  722. font-weight: 500;
  723. font-size: 26rpx;
  724. color: #333333;
  725. line-height: 36rpx;
  726. text-align: left;
  727. font-style: normal;
  728. .circle {
  729. width: 32rpx;
  730. height: 32rpx;
  731. margin-right: 10rpx;
  732. }
  733. }
  734. }
  735. }
  736. .shopcart {
  737. font-family: PingFangSC, PingFang SC;
  738. font-weight: 500;
  739. font-size: 36rpx;
  740. color: #222222;
  741. line-height: 50rpx;
  742. text-align: right;
  743. font-style: normal;
  744. }
  745. .sum {
  746. font-family: HarmonyOS_Sans;
  747. font-size: 22rpx;
  748. color: #333333;
  749. line-height: 32rpx;
  750. text-align: left;
  751. font-style: normal;
  752. }
  753. .down {
  754. position: absolute;
  755. top: 0;
  756. left: 0;
  757. background-color: #c7c7c7;
  758. opacity: 0.7;
  759. width: 100%;
  760. height: 100%;
  761. z-index: 10000;
  762. border-radius: 20rpx;
  763. }
  764. </style>