activity.vue 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <template>
  2. <view>
  3. <view v-if="isShow" class="specialArea acea-row row-between-wrapper">
  4. <view class="assemble skeleton-rect" hover-class="none" @click="gopage(activityOne.info[2].value)">
  5. <!-- <easy-loadimage mode="widthFix" :image-src="activityOne.img"></easy-loadimage> -->
  6. <image :src="activityOne.img" alt="" srcset="">
  7. <!-- <view class="text" v-if="activityOne.info">
  8. <view class="name">{{ activityOne.info[0].value }}</view>
  9. <view class="infor">{{ activityOne.info[1].value }}</view>
  10. </view> -->
  11. </view>
  12. <view class="list acea-row row-column-between">
  13. <view class="item skeleton-rect" v-for="(item, index) in activity" :key="index"
  14. @click="gopage(item.info[2].value)">
  15. <easy-loadimage mode="widthFix" :image-src="item.img"></easy-loadimage>
  16. <!-- <view class="text">
  17. <view class="name">{{ item.info[0].value }}</view>
  18. <view class="infor">{{ item.info[1].value}}</view>
  19. </view> -->
  20. </view>
  21. </view>
  22. </view>
  23. <view v-if="!isShow && isIframe" class="specialArea acea-row row-between-wrapper">
  24. <view class="assemble" hover-class="none" @click="gopage(activityOne.info[2].value)">
  25. <image :src="activityOne.img" alt="img" />
  26. <!-- <view class="text" v-if="activityOne.info">
  27. <view class="name">{{ activityOne.info[0].value }}</view>
  28. <view class="infor">{{ activityOne.info[1].value }}</view>
  29. </view> -->
  30. </view>
  31. <view class="list acea-row row-column-between">
  32. <view class="item" v-for="(item, index) in activity" :key="index" @click="gopage(item.info[2].value)">
  33. <image :src="item.img" alt="img" />
  34. <!-- <view class="text">
  35. <view class="name">{{ item.info[0].value }}</view>
  36. <view class="infor">{{ item.info[1].value}}</view>
  37. </view> -->
  38. </view>
  39. </view>
  40. </view>
  41. </view>
  42. </template>
  43. <script>
  44. let app = getApp()
  45. import {
  46. goPage
  47. } from '@/libs/order.js'
  48. export default {
  49. name: 'activity',
  50. props: {
  51. dataConfig: {
  52. type: Object,
  53. default: () => {}
  54. }
  55. },
  56. watch: {
  57. dataConfig: {
  58. immediate: true,
  59. handler(nVal, oVal) {
  60. if (nVal) {
  61. let data = JSON.parse(JSON.stringify(nVal.imgList.list))
  62. this.activityOne = nVal.imgList.list[0]
  63. data.splice(0, 1)
  64. this.activity = data
  65. this.isShow = nVal.isShow.val
  66. }
  67. }
  68. }
  69. },
  70. data() {
  71. return {
  72. activity: [],
  73. activityOne: {},
  74. name: this.$options.name,
  75. isShow: true,
  76. isIframe: app.globalData.isIframe
  77. }
  78. },
  79. created() {},
  80. methods: {
  81. gopage(url) {
  82. goPage().then(res => {
  83. this.$util.JumpPath(url);
  84. })
  85. }
  86. }
  87. }
  88. </script>
  89. <style lang="scss" scoped>
  90. .specialArea {
  91. background: linear-gradient(180deg, #fff 0%, #f5f5f5 100%);
  92. // background-color: $uni-bg-color;
  93. padding: 0 $uni-index-margin-col 0 $uni-index-margin-col;
  94. border-radius: $uni-border-radius-index;
  95. // box-shadow: $uni-index-box-shadow;
  96. }
  97. .specialArea .assemble {
  98. width: 336rpx;
  99. height: 300rpx;
  100. position: relative;
  101. }
  102. .specialArea .assemble image {
  103. width: 100%;
  104. height: 100%;
  105. border-radius: 5rpx;
  106. }
  107. .specialArea .assemble {
  108. /deep/,
  109. /deep/image,
  110. /deep/.easy-loadimage,
  111. /deep/uni-image {
  112. width: 336rpx;
  113. height: 300rpx;
  114. border-radius: 5rpx;
  115. }
  116. }
  117. .specialArea .assemble .text {
  118. position: absolute;
  119. top: 37rpx;
  120. left: 22rpx;
  121. }
  122. .specialArea .name {
  123. font-size: 30rpx;
  124. color: #fff;
  125. }
  126. .specialArea .infor {
  127. font-size: 22rpx;
  128. color: rgba(255, 255, 255, 0.8);
  129. margin-top: 5rpx;
  130. }
  131. .specialArea .list {
  132. width: 344rpx;
  133. height: 300rpx;
  134. }
  135. .specialArea .item {
  136. width: 100%;
  137. height: 146rpx;
  138. position: relative;
  139. }
  140. .specialArea .item img {
  141. width: 100%;
  142. height: 100%;
  143. }
  144. .specialArea .item {
  145. /deep/,
  146. /deep/image,
  147. /deep/.easy-loadimage,
  148. /deep/uni-image {
  149. width: 100%;
  150. height: 146rpx;
  151. }
  152. }
  153. .specialArea .item .text {
  154. position: absolute;
  155. top: 23rpx;
  156. left: 28rpx;
  157. }
  158. .specialArea .item image {
  159. width: 100%;
  160. height: 100%;
  161. }
  162. .specialArea .item .text {
  163. position: absolute;
  164. top: 23rpx;
  165. left: 28rpx;
  166. }
  167. </style>