createOrder.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789
  1. <template>
  2. <view>
  3. <navigator v-if="tabCurrentIndex == 0" url="/pages/set/address?source=1" class="address-section">
  4. <view class="order-content" v-if="addressData.real_name">
  5. <text class="iconfont iconlocation"></text>
  6. <view class="cen">
  7. <view class="top">
  8. <text class="name">{{ addressData.real_name }}</text>
  9. <text class="mobile">{{ addressData.phone }}</text>
  10. </view>
  11. <text class="address">{{ addressData.province + addressData.city + addressData.district }} {{ addressData.detail }}</text>
  12. </view>
  13. <text class="iconfont iconenter"></text>
  14. </view>
  15. <view class="order-content" v-if="!addressData.real_name">
  16. <view class="addAddress">
  17. <text class="iconfont iconaddition"></text>
  18. <text>添加收货地址</text>
  19. </view>
  20. </view>
  21. <image class="a-bg" :src="addressImg"></image>
  22. </navigator>
  23. <view class="goods-section" v-for="(ls, ind) in shopList" :key="ind">
  24. <view class="g-item">
  25. <image :src="ls.productInfo.image"></image>
  26. <view class="right">
  27. <text class="title clamp">{{ ls.productInfo.store_name }}</text>
  28. <text class="spec">{{ ls.productInfo.attrInfo ? ls.productInfo.attrInfo.suk : '默认' }}</text>
  29. <view class="price-box" v-if="goodsType != 0">
  30. <text class="price">{{ ls.productInfo.attrInfo ? ls.productInfo.attrInfo.money * 1 + ls.money_type_name : ls.productInfo.money * 1 + ls.money_type_name }}</text>
  31. <text class="number">{{ 'x ' + ls.cart_num + (ls.productInfo.unit_name || '') }}</text>
  32. </view>
  33. <view class="price-box" v-else>
  34. <text class="price">{{ ls.productInfo.attrInfo ? ls.productInfo.attrInfo.price * 1 : ls.productInfo.price * 1 }}</text>
  35. <text class="number">{{ 'x ' + ls.cart_num + (ls.productInfo.unit_name || '') }}</text>
  36. </view>
  37. </view>
  38. </view>
  39. </view>
  40. <!-- 优惠明细 -->
  41. <view class="yt-list">
  42. <view class="yt-list-cell b-b" v-if="moneyAll.storeFreePostage > 0">
  43. <view class="cell-icon hb">减</view>
  44. <text class="cell-tit clamp">商家促销</text>
  45. <text class="cell-tip disabled">满{{ moneyAll.storeFreePostage }}包邮</text>
  46. </view>
  47. </view>
  48. <!-- 金额明细 -->
  49. <view class="yt-list">
  50. <view class="yt-list-cell b-b" v-if="is_integral == 1">
  51. <text class="cell-tit clamp">金券抵扣{{ '(当前金券:' + integralAll + ')' }}</text>
  52. <view class="cell-tip"><radio @click="checkedPoints = !checkedPoints" color=" #5dbc7c" :checked="checkedPoints" /></view>
  53. </view>
  54. <view class="yt-list-cell b-b">
  55. <text class="cell-tit clamp">运费</text>
  56. <text class="cell-tip">{{ Postage }}</text>
  57. </view>
  58. <view class="yt-list-cell b-b">
  59. <text class="cell-tit clamp">备注</text>
  60. <input class="desc" type="text" v-model="desc" placeholder="请填写备注信息" placeholder-class="placeholder" />
  61. </view>
  62. </view>
  63. <view class="yt-list" >
  64. <view class="yt-list-cell b-b">
  65. <text class="cell-tit clamp">还需支付</text>
  66. <text class="cell-tip">¥{{ payAllMoney }}</text>
  67. </view>
  68. <view class="yt-list-cell b-b" v-if="checkedPoints && integralShow">
  69. <text class="cell-tit clamp">金券抵扣</text>
  70. <text class="cell-tip">-¥{{ integralMoney }}</text>
  71. </view>
  72. <view class="yt-list-cell b-b" v-if="moneyAll.vipPrice > 0">
  73. <text class="cell-tit clamp">VIP优惠</text>
  74. <text class="cell-tip">-¥{{ moneyAll.vipPrice }}</text>
  75. </view>
  76. </view>
  77. <!-- 底部 -->
  78. <view class="footer">
  79. <view class="price-content">
  80. <text>实付款</text>
  81. <text class="price-tip" v-if="goodsType == 0">¥</text>
  82. <text class="price">{{ payPrice }}</text>
  83. </view>
  84. <text class="submit" :class="{ submitNo: !payType }" @click="payType ? submit() : ''">提交订单</text>
  85. </view>
  86. <!-- 优惠券面板 -->
  87. <view class="mask" :class="maskState === 0 ? 'none' : maskState === 1 ? 'show' : ''" @click="toggleMask">
  88. <view class="mask-content">
  89. <!-- 优惠券页面,仿mt -->
  90. <view class="coupon-item" @click="checkedCp(item)" v-for="(item, index) in couponList" :key="index">
  91. <view class="con">
  92. <view class="left">
  93. <text class="title">{{ item.coupon_title }}</text>
  94. <text class="time">领取时间{{ item.add_time }}</text>
  95. </view>
  96. <view class="right">
  97. <text class="price">{{ item.coupon_price }}</text>
  98. <text>满{{ item.use_min_price }}可用</text>
  99. </view>
  100. <view class="circle l"></view>
  101. <view class="circle r"></view>
  102. </view>
  103. <text class="tips">有效期至{{ item.end_time }}</text>
  104. </view>
  105. </view>
  106. </view>
  107. </view>
  108. </template>
  109. <script>
  110. import { confirm,computedOrderkey,couponsOrder } from '@/api/order.js';
  111. import { getUserInfo } from '@/api/user.js';
  112. import { cartAdd } from '@/api/product.js';
  113. export default {
  114. data() {
  115. return {
  116. is_beauty: 0,
  117. addressImg:
  118. '',
  119. // 当前选中的支付方式
  120. tabCurrentIndex: 0,
  121. maskState: 0, //优惠券面板显示状态
  122. desc: '', //备注
  123. payType: 1, //1微信 2支付宝
  124. // 优惠券列表
  125. couponList: [],
  126. couponListshow: false, //是有可以显示优惠券列表
  127. couponChecked: {}, //选中的优惠券
  128. // 收货地址
  129. addressData: {},
  130. is_gold:0,
  131. is_integral:0,
  132. // 店铺地址
  133. shopAddress: {
  134. name: '',
  135. mobile: '',
  136. addressName: '',
  137. address: '',
  138. area: '',
  139. default: false
  140. },
  141. // 商品列表
  142. shopList: [],
  143. // 购物车id
  144. cartId: '',
  145. //购物金额详情
  146. moneyAll: {
  147. storeFreePostage: 0, //邮费优惠
  148. storePostage: 0, //邮费
  149. totalPrice: 0, //总支付金额
  150. vipPrice: 0 //vip优惠价
  151. },
  152. payPrice: "", //总支付金额
  153. orderKey: '', //订单id
  154. checkedPoints: false, //判断是否积分抵扣
  155. integralAll: 0, //可使用的积分
  156. integralMoney: 0, //积分抵扣金额
  157. integralShow: false, //是否显示积分抵扣金额
  158. payType: true, //是否可支付
  159. pinkid: '', //保存拼团商品id
  160. goodsType:'',
  161. money_type:[],//保存支付金额单位
  162. };
  163. },
  164. onLoad(option) {
  165. // 判断是否是金券商品
  166. if (option.is_integral){
  167. this.is_integral = option.is_integral
  168. }
  169. if(option.is_beauty) {
  170. this.is_beauty = option.is_beauty
  171. }
  172. // 判断是否是金豆商品
  173. if (option.is_gold){
  174. this.is_gold = option.is_gold
  175. }
  176. if (option.goodsType){
  177. this.goodsType = option.goodsType
  178. }
  179. // 判断是否为拼团商品
  180. if (option.type == 'pink') {
  181. this.pinkid = option.pinkId;
  182. this.cartAdd(option);
  183. } else {
  184. // 保存当前商品在购物车中的id
  185. this.cartId = option.id;
  186. this.loadData();
  187. }
  188. this.getUserInfo();
  189. },
  190. watch: {
  191. checkedPoints(newValue, oldValue) {
  192. this.integralShow = false;
  193. this.payMoneyNub();
  194. },
  195. addressData(newValue, oldValue) {
  196. this.payMoneyNub();
  197. }
  198. },
  199. computed: {
  200. Postage() {
  201. let money = +this.moneyAll.storePostage;
  202. if (money == 0) {
  203. return '免运费';
  204. } else {
  205. return '¥' + money;
  206. }
  207. },
  208. payAllMoney() {
  209. return +this.moneyAll.totalPrice + +this.moneyAll.vipPrice;
  210. }
  211. },
  212. methods: {
  213. // 添加商品到购物车
  214. cartAdd(opt) {
  215. let obj = this;
  216. cartAdd({
  217. cartNum: 1, //商品数量
  218. new: 1, //商品是否新增加到购物车1为不加入0为加入
  219. mer_id: +opt.merid, //商店id
  220. combinationId: +opt.gid, //拼团商品id
  221. productId: +opt.pid //普通商品id
  222. })
  223. .then(function(e) {
  224. let da = e.data;
  225. // 獲取购物车号
  226. obj.cartId = da.cartId;
  227. // 加载数据
  228. obj.loadData();
  229. })
  230. .catch(e => {
  231. console.log(e);
  232. });
  233. },
  234. // 加载用户基础信息
  235. getUserInfo() {
  236. getUserInfo({}).then(({ data }) => {
  237. this.integralAll = data.integral;
  238. });
  239. },
  240. // 计算支付金额
  241. payMoneyNub() {
  242. computedOrderkey({
  243. orderkey: this.orderKey,
  244. useIntegral: this.checkedPoints ? 1 : 0, //是否积分抵扣
  245. couponId: this.couponChecked.id, //优惠券编号
  246. addressId: this.addressData.id //地址编号
  247. })
  248. .then(({ data }) => {
  249. const obj = this
  250. console.log(data,'111');
  251. this.payType = true;
  252. this.integralShow = true;
  253. // 获取支付金额
  254. if(this.goodsType == 0){
  255. this.payPrice = +data.result.pay_price;
  256. }else {
  257. const arr = Object.keys(data.result.exchangeMoney);
  258. const ar = Object.keys(obj.money_type);
  259. arr.forEach(e => {
  260. ar.forEach(b =>{
  261. if (e == b){
  262. obj.payPrice += data.result.exchangeMoney[e] * 1 + obj.money_type[b]
  263. }
  264. })
  265. console.log(obj.money_type,'123456')
  266. });
  267. if(data.result.pay_price != 0){
  268. obj.payPrice += "+¥" + data.result.pay_price
  269. }
  270. }
  271. this.integralMoney = data.result.deduction_price;
  272. })
  273. .catch(e => {
  274. console.log(e);
  275. this.integralShow = false;
  276. this.payType = false;
  277. });
  278. },
  279. // 是否使用积分
  280. checkedIntegral() {
  281. this.checkedPoints = !this.checkedPoints;
  282. },
  283. loadData() {
  284. let obj = this;
  285. console.log(123456)
  286. confirm({ cartId: obj.cartId+'' }).then(({ data }) => {
  287. obj.addressData = data.addressInfo || {};
  288. obj.shopList = data.cartInfo; //商品列表
  289. obj.moneyAll = data.priceGroup; //金额数据
  290. obj.orderKey = data.orderKey; //订单key
  291. obj.money_type = data.money_type; // 金额单位
  292. // 计算金额
  293. this.payMoneyNub();
  294. // 加载优惠券
  295. // obj.couponsOrder(data.priceGroup.totalPrice);
  296. });
  297. },
  298. // 购买数量变化
  299. numberChange(data) {
  300. this.number = data.number;
  301. },
  302. // 修改支付方式
  303. changePayType(type) {
  304. this.payType = type;
  305. },
  306. // 提交订单
  307. submit() {
  308. if (this.checkedPoints && this.shopList.length > 1) {
  309. this.$api.msg('积分商品只可单件购买');
  310. return false;
  311. }
  312. if (!this.addressData.real_name) {
  313. this.$api.msg('请选择收货地址');
  314. return false;
  315. }
  316. let url = '/pages/money/pay?key='+ this.orderKey + '&is_gold=' + this.is_gold
  317. if(this.pinkid){
  318. url += '&pinkid='+this.pinkid
  319. }
  320. uni.navigateTo({
  321. url
  322. });
  323. }
  324. }
  325. };
  326. </script>
  327. <style lang="scss">
  328. page {
  329. background: $page-color-base;
  330. padding-bottom: 100rpx;
  331. }
  332. .navbar {
  333. display: flex;
  334. height: 80rpx;
  335. padding: 0 5px;
  336. background: #fff;
  337. box-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.06);
  338. position: relative;
  339. z-index: 10;
  340. .nav-item {
  341. flex: 1;
  342. display: flex;
  343. justify-content: center;
  344. align-items: center;
  345. height: 100%;
  346. font-size: $font-lg + 4rpx;
  347. color: $font-color-dark;
  348. position: relative;
  349. &.current {
  350. color: $base-color;
  351. &:after {
  352. content: '';
  353. position: absolute;
  354. left: 50%;
  355. bottom: 0;
  356. transform: translateX(-50%);
  357. width: 140rpx;
  358. height: 0;
  359. border-bottom: 2px solid $base-color;
  360. }
  361. }
  362. }
  363. }
  364. .address-section {
  365. padding: 30rpx 0;
  366. background: #fff;
  367. position: relative;
  368. border-top: 1px solid $border-color-light;
  369. .order-content {
  370. min-height: 100rpx;
  371. display: flex;
  372. align-items: center;
  373. .addAddress {
  374. text-align: center;
  375. width: 100%;
  376. display: flex;
  377. justify-content: center;
  378. align-items: center;
  379. .iconaddition {
  380. font-size: 55rpx;
  381. line-height: 1;
  382. border-radius: 100rpx;
  383. margin-right: 20rpx;
  384. }
  385. }
  386. }
  387. .iconlocation {
  388. flex-shrink: 0;
  389. display: flex;
  390. align-items: center;
  391. justify-content: center;
  392. width: 90rpx;
  393. color: #888;
  394. font-size: 44rpx;
  395. }
  396. .cen {
  397. display: flex;
  398. flex-direction: column;
  399. flex: 1;
  400. font-size: 28rpx;
  401. color: $font-color-dark;
  402. }
  403. .name {
  404. font-size: 34rpx;
  405. margin-right: 24rpx;
  406. }
  407. .address {
  408. margin-top: 16rpx;
  409. margin-right: 20rpx;
  410. color: $font-color-light;
  411. }
  412. .icon-you {
  413. font-size: 32rpx;
  414. color: $font-color-light;
  415. margin-right: 30rpx;
  416. }
  417. .a-bg {
  418. position: absolute;
  419. left: 0;
  420. bottom: 0;
  421. display: block;
  422. width: 100%;
  423. height: 5rpx;
  424. }
  425. }
  426. .goods-section {
  427. margin-top: 16rpx;
  428. background: #fff;
  429. padding-bottom: 1px;
  430. .g-header {
  431. display: flex;
  432. align-items: center;
  433. height: 84rpx;
  434. padding: 0 30rpx;
  435. position: relative;
  436. }
  437. .logo {
  438. display: block;
  439. width: 50rpx;
  440. height: 50rpx;
  441. border-radius: 100px;
  442. }
  443. .name {
  444. font-size: 30rpx;
  445. color: $font-color-base;
  446. margin-left: 24rpx;
  447. }
  448. .g-item {
  449. display: flex;
  450. margin: 20rpx 30rpx;
  451. image {
  452. flex-shrink: 0;
  453. display: block;
  454. width: 140rpx;
  455. height: 140rpx;
  456. border-radius: 4rpx;
  457. }
  458. .right {
  459. flex: 1;
  460. padding-left: 24rpx;
  461. overflow: hidden;
  462. }
  463. .title {
  464. font-size: 30rpx;
  465. color: $font-color-dark;
  466. }
  467. .spec {
  468. font-size: 26rpx;
  469. color: $font-color-light;
  470. }
  471. .price-box {
  472. display: flex;
  473. align-items: center;
  474. font-size: 32rpx;
  475. color: $font-color-dark;
  476. padding-top: 10rpx;
  477. .price {
  478. margin-bottom: 4rpx;
  479. color: $color-red;
  480. }
  481. .number {
  482. font-size: 26rpx;
  483. color: $font-color-base;
  484. margin-left: 20rpx;
  485. }
  486. }
  487. .step-box {
  488. position: relative;
  489. }
  490. }
  491. }
  492. .yt-list {
  493. margin-top: 16rpx;
  494. background: #fff;
  495. }
  496. .yt-list-cell {
  497. display: flex;
  498. align-items: center;
  499. padding: 10rpx 30rpx 10rpx 40rpx;
  500. line-height: 70rpx;
  501. position: relative;
  502. &.cell-hover {
  503. background: #fafafa;
  504. }
  505. &.b-b:after {
  506. left: 30rpx;
  507. }
  508. .cell-icon {
  509. height: 32rpx;
  510. width: 32rpx;
  511. font-size: 22rpx;
  512. color: #fff;
  513. text-align: center;
  514. line-height: 32rpx;
  515. background: #f85e52;
  516. border-radius: 4rpx;
  517. margin-right: 12rpx;
  518. &.hb {
  519. background: #ffaa0e;
  520. }
  521. &.lpk {
  522. background: #3ab54a;
  523. }
  524. }
  525. .cell-more {
  526. align-self: center;
  527. font-size: 24rpx;
  528. color: $font-color-light;
  529. margin-left: 8rpx;
  530. margin-right: -10rpx;
  531. }
  532. .cell-tit {
  533. flex: 1;
  534. font-size: 26rpx;
  535. color: $font-color-light;
  536. margin-right: 10rpx;
  537. }
  538. .cell-tip {
  539. font-size: 26rpx;
  540. color: $font-color-dark;
  541. &.disabled {
  542. color: $font-color-light;
  543. }
  544. &.active {
  545. color: $base-color;
  546. }
  547. &.red {
  548. color: $base-color;
  549. }
  550. }
  551. &.desc-cell {
  552. .cell-tit {
  553. max-width: 90rpx;
  554. }
  555. }
  556. .desc {
  557. flex: 1;
  558. text-align: right;
  559. font-size: $font-base;
  560. color: $font-color-dark;
  561. }
  562. }
  563. /* 支付列表 */
  564. .pay-list {
  565. padding-left: 40rpx;
  566. margin-top: 16rpx;
  567. background: #fff;
  568. .pay-item {
  569. display: flex;
  570. align-items: center;
  571. padding-right: 20rpx;
  572. line-height: 1;
  573. height: 110rpx;
  574. position: relative;
  575. }
  576. .icon-weixinzhifu {
  577. width: 80rpx;
  578. font-size: 40rpx;
  579. color: #6bcc03;
  580. }
  581. .icon-alipay {
  582. width: 80rpx;
  583. font-size: 40rpx;
  584. color: #06b4fd;
  585. }
  586. .icon-xuanzhong2 {
  587. display: flex;
  588. align-items: center;
  589. justify-content: center;
  590. width: 60rpx;
  591. height: 60rpx;
  592. font-size: 40rpx;
  593. color: $base-color;
  594. }
  595. .tit {
  596. font-size: 32rpx;
  597. color: $font-color-dark;
  598. flex: 1;
  599. }
  600. }
  601. .footer {
  602. position: fixed;
  603. left: 0;
  604. bottom: 0;
  605. z-index: 995;
  606. display: flex;
  607. align-items: center;
  608. width: 100%;
  609. height: 90rpx;
  610. justify-content: space-between;
  611. font-size: 30rpx;
  612. background-color: #fff;
  613. z-index: 998;
  614. color: $font-color-base;
  615. box-shadow: 0 -1px 5px rgba(0, 0, 0, 0.1);
  616. .price-content {
  617. padding-left: 30rpx;
  618. }
  619. .price-tip {
  620. color: $font-color-base;
  621. margin-left: 8rpx;
  622. }
  623. .price {
  624. font-size: 36rpx;
  625. color: $font-color-base;
  626. }
  627. .submit {
  628. display: flex;
  629. align-items: center;
  630. justify-content: center;
  631. width: 280rpx;
  632. height: 100%;
  633. color: #fff;
  634. font-size: 32rpx;
  635. background-color: $base-color;
  636. &.submitNo {
  637. background-color: $font-color-disabled;
  638. }
  639. }
  640. }
  641. /* 优惠券面板 */
  642. .mask {
  643. display: flex;
  644. align-items: flex-end;
  645. position: fixed;
  646. left: 0;
  647. top: var(--window-top);
  648. bottom: 0;
  649. width: 100%;
  650. background: rgba(0, 0, 0, 0);
  651. z-index: 9995;
  652. transition: 0.3s;
  653. .mask-content {
  654. width: 100%;
  655. max-height: 70vh;
  656. background: #f3f3f3;
  657. transform: translateY(100%);
  658. transition: 0.3s;
  659. overflow-y: scroll;
  660. }
  661. &.none {
  662. display: none;
  663. }
  664. &.show {
  665. background: rgba(0, 0, 0, 0.4);
  666. .mask-content {
  667. transform: translateY(0);
  668. }
  669. }
  670. }
  671. /* 优惠券列表 */
  672. .coupon-item {
  673. display: flex;
  674. flex-direction: column;
  675. margin: 20rpx 24rpx;
  676. background: #fff;
  677. .con {
  678. display: flex;
  679. align-items: center;
  680. position: relative;
  681. height: 120rpx;
  682. padding: 0 30rpx;
  683. &:after {
  684. position: absolute;
  685. left: 0;
  686. bottom: 0;
  687. content: '';
  688. width: 100%;
  689. height: 0;
  690. border-bottom: 1px dashed #f3f3f3;
  691. transform: scaleY(50%);
  692. }
  693. }
  694. .left {
  695. display: flex;
  696. flex-direction: column;
  697. justify-content: center;
  698. flex: 1;
  699. overflow: hidden;
  700. height: 100rpx;
  701. }
  702. .title {
  703. font-size: 32rpx;
  704. color: $font-color-dark;
  705. margin-bottom: 10rpx;
  706. }
  707. .time {
  708. font-size: 24rpx;
  709. color: $font-color-light;
  710. }
  711. .right {
  712. display: flex;
  713. flex-direction: column;
  714. justify-content: center;
  715. align-items: center;
  716. font-size: 26rpx;
  717. color: $font-color-base;
  718. height: 100rpx;
  719. }
  720. .price {
  721. font-size: 44rpx;
  722. color: $base-color;
  723. &:before {
  724. content: '¥';
  725. font-size: 34rpx;
  726. }
  727. }
  728. .tips {
  729. font-size: 24rpx;
  730. color: $font-color-light;
  731. line-height: 60rpx;
  732. padding-left: 30rpx;
  733. }
  734. .circle {
  735. position: absolute;
  736. left: -6rpx;
  737. bottom: -10rpx;
  738. z-index: 10;
  739. width: 20rpx;
  740. height: 20rpx;
  741. background: #f3f3f3;
  742. border-radius: 100px;
  743. &.r {
  744. left: auto;
  745. right: -6rpx;
  746. }
  747. }
  748. }
  749. </style>