service-card.vue 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <template>
  2. <view class="service-card">
  3. <view class="service-row" @click="onClick">
  4. <view class="icon-box">
  5. <image src="/pages-sell/static/goods/icon-down.png" class="service-icon" mode="aspectFit"></image>
  6. </view>
  7. <text class="service-label">可降</text>
  8. <text class="separator">|</text>
  9. <text class="service-val red">分享一人助力,可降 1.5 元</text>
  10. <u-icon name="arrow-right" size="24" color="#999" class="arrow"></u-icon>
  11. </view>
  12. <view class="service-row">
  13. <view class="icon-box">
  14. <image src="/pages-sell/static/goods/icon-fee.png" class="service-icon" mode="aspectFit"></image>
  15. </view>
  16. <text class="service-label">运费</text>
  17. <text class="separator">|</text>
  18. <text class="service-val green">全场满 5.8 元包邮(偏远地区除外)</text>
  19. </view>
  20. <view class="service-row">
  21. <view class="icon-box">
  22. <image src="/pages-sell/static/goods/icon-fire.png" class="service-icon" mode="aspectFit"></image>
  23. </view>
  24. <text class="service-label">活动</text>
  25. <text class="separator">|</text>
  26. <text class="service-val red">每满 48 元减 5 元</text>
  27. </view>
  28. <view class="service-row last">
  29. <view class="icon-box">
  30. <image src="/pages-sell/static/goods/icon-service.png" class="service-icon" mode="aspectFit"></image>
  31. </view>
  32. <text class="service-label">服务</text>
  33. <text class="separator">|</text>
  34. <text class="service-val">破损包赔 · 降价补差 · 24 小时发货</text>
  35. </view>
  36. </view>
  37. </template>
  38. <script>
  39. export default {
  40. name: 'ServiceCard',
  41. methods: {
  42. onClick() {
  43. this.$emit('click');
  44. }
  45. }
  46. }
  47. </script>
  48. <style lang="scss" scoped>
  49. .service-card {
  50. background: #fff;
  51. border-radius: 24rpx 24rpx 0 0;
  52. padding: 0 30rpx;
  53. margin-bottom: 20rpx;
  54. .service-row {
  55. display: flex;
  56. align-items: center;
  57. padding: 30rpx 0;
  58. font-size: 26rpx;
  59. position: relative;
  60. border-bottom: 1rpx solid #F5F5F5;
  61. &.last {
  62. border-bottom: none;
  63. }
  64. .icon-box {
  65. width: 32rpx;
  66. height: 32rpx;
  67. margin-right: 12rpx;
  68. display: flex;
  69. align-items: center;
  70. justify-content: center;
  71. .service-icon {
  72. width: 100%;
  73. height: 100%;
  74. }
  75. }
  76. .service-label {
  77. color: #333;
  78. font-weight: bold;
  79. width: 50rpx; // Fixed width for 2 characters to ensure alignment
  80. text-align: justify;
  81. text-align-last: justify;
  82. }
  83. .separator {
  84. color: #eee;
  85. margin: 0 10rpx;
  86. }
  87. .service-val {
  88. color: #666;
  89. &.red {
  90. color: #D81A00;
  91. }
  92. &.green {
  93. color: #38C248;
  94. }
  95. }
  96. .arrow {
  97. position: absolute;
  98. right: 0;
  99. }
  100. }
  101. }
  102. </style>