index.vue 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. <template>
  2. <div class="com-main">
  3. <carousel
  4. v-if="indexBanner.length"
  5. :banner="indexBanner"
  6. :height="'538px'"></carousel>
  7. <sub-nav :secondaryBanner="secondaryBanner"></sub-nav>
  8. <section class="com-width-1200 com-margin-auto">
  9. <pc-title :title="'Trending Products'"></pc-title>
  10. <div class="card-wrap com-margin-auto">
  11. <card
  12. v-for="(item, k) in indexGoodsRankLists"
  13. :key="k"
  14. :cardData="item"
  15. ref="card"
  16. @addCompare="addCompareList"></card>
  17. <transition
  18. @before-enter="beforeEnter"
  19. @enter="enter"
  20. @after-enter="afterEnter">
  21. <div
  22. class="ball"
  23. v-show="shopCarBall"
  24. ref="ball">
  25. <div class="linner_ball"></div>
  26. </div>
  27. </transition>
  28. </div>
  29. </section>
  30. <a
  31. :href="midBanner[0]?.link"
  32. target="_target"
  33. v-if="midBanner.length">
  34. <el-image
  35. lazy
  36. :src="midBanner[0]?.image"
  37. alt="why choose us"
  38. class="middle_banner"
  39. fit="cover"></el-image>
  40. </a>
  41. <section class="com-width-1400 com-margin-auto row-card">
  42. <row-card
  43. v-for="(item, k) in articleList"
  44. :key="k"
  45. :data="item"></row-card>
  46. <!-- <subscription></subscription> -->
  47. </section>
  48. <no-ssr>
  49. <div
  50. class="cookie-dialog"
  51. v-show="!canUseCookie">
  52. <div class="cookie-dialog-wrap">
  53. <div class="cookie-dialog-title">Our Cookies</div>
  54. <div class="cookie-dialog-content">
  55. We use cookies to provide website functionality, to analyze traffic
  56. on our website, personalize content, serve targeted advertisements
  57. and to enable social media functionality.
  58. </div>
  59. <div class="flex center">
  60. <button
  61. class="btn"
  62. @click="dialogAskCookieVisible = true">
  63. Privacy policy
  64. </button>
  65. <button
  66. class="btn"
  67. @click="allowCookie">
  68. Allow all
  69. </button>
  70. </div>
  71. </div>
  72. </div>
  73. </no-ssr>
  74. <el-dialog
  75. :visible.sync="dialogAskCookieVisible"
  76. width="400"
  77. title="Privacy policy">
  78. We use cookies to provide website functionality, to analyze traffic on our
  79. website, personalize content, serve targeted advertisements and to enable
  80. social media functionality. Our cookie statement provides more information
  81. in our Privacy Policy page.
  82. </el-dialog>
  83. </div>
  84. </template>
  85. <script>
  86. export default {
  87. name: 'IndexPage',
  88. layout: 'default',
  89. async asyncData({ $axios, req }) {
  90. // type:1、首页顶部banner,2、首页小图推荐,3、中部banner,4、,5、推荐文章栏目,6、底部banner,7、社交链接
  91. const indexBanner = await $axios.post('/uk-api/home/indexBanner', {
  92. type: 1,
  93. })
  94. const secondaryBanner = await $axios.post('/uk-api/home/indexBanner', {
  95. type: 2,
  96. })
  97. const indexGoodsRankLists = await $axios.post(
  98. '/uk-api/home/indexGoodsRankList'
  99. )
  100. const midBanner = await $axios.post('/uk-api/home/indexBanner', {
  101. type: 3,
  102. })
  103. const articleList = await $axios.post('/uk-api/home/indexBanner', {
  104. type: 5,
  105. })
  106. return {
  107. indexBanner: indexBanner.result.data,
  108. secondaryBanner: secondaryBanner.result.data,
  109. indexGoodsRankLists: indexGoodsRankLists.result,
  110. midBanner: midBanner.result.data,
  111. articleList: articleList.result.data,
  112. }
  113. },
  114. data() {
  115. return {
  116. indexBanner: [],
  117. secondaryBanner: [],
  118. indexGoodsRankLists: [],
  119. midBanner: [],
  120. articleList: [],
  121. shopCarBall: false,
  122. shopCarBallEl: null,
  123. ss: null,
  124. canUseCookie: false,
  125. dialogAskCookieVisible: false,
  126. }
  127. },
  128. beforeMount() {
  129. this.canUseCookie = !!this.$cookies.get('can-use-cookie') || false
  130. },
  131. methods: {
  132. allowCookie() {
  133. this.$cookies.set('can-use-cookie', true)
  134. this.$nextTick(() => {
  135. this.canUseCookie = this.$cookies.get('can-use-cookie') || false
  136. })
  137. },
  138. addCompareList(target) {
  139. this.shopCarBallEl = target
  140. this.shopCarBall = true
  141. },
  142. // 动画开始
  143. beforeEnter(el) {
  144. // 获取元素的大小及其相对于视口的位置
  145. if (process.client) {
  146. const dom = this.shopCarBallEl.getBoundingClientRect()
  147. const comparePosition = document
  148. .querySelector('.compare-list')
  149. .getBoundingClientRect()
  150. const offsetX = comparePosition.left - dom.left
  151. const offsetY = dom.top - comparePosition.top - 20
  152. el.style.display = ''
  153. // y轴是曲直向上的,x轴是蜿蜒的向右的
  154. el.style.transform = `translate3D( -${offsetX}px,${offsetY}px,0)`
  155. }
  156. },
  157. enter(el, done) {
  158. // 触发重绘,来实现动画的移动过程
  159. if (process.client) {
  160. this.ss = document.body.offsetHeight
  161. el.style.transform = `translate3D( 0,0,0)`
  162. el.addEventListener('transitionend', done)
  163. }
  164. },
  165. afterEnter(el) {
  166. this.shopCarBall = false
  167. el.style.display = 'none'
  168. },
  169. },
  170. }
  171. </script>
  172. <style lang="scss" scoped>
  173. .card-wrap {
  174. display: grid;
  175. justify-items: center;
  176. justify-content: space-evenly;
  177. // grid-template-columns: repeat(5,1fr);
  178. }
  179. .middle_banner {
  180. width: 100%;
  181. height: 580px;
  182. margin: 0 0 30px;
  183. }
  184. .ball {
  185. position: fixed;
  186. top: 86px;
  187. right: 19%;
  188. width: 20px;
  189. height: 20px;
  190. border-radius: 50%;
  191. background: #e90000;
  192. transition: all 0.5s linear;
  193. z-index: 9999;
  194. .linner_ball {
  195. transition: all 0.5s linear;
  196. }
  197. }
  198. .cookie-dialog {
  199. position: fixed;
  200. top: 0;
  201. left: 0;
  202. width: 100%;
  203. height: 100%;
  204. background-color: rgba(#222, 0.3);
  205. color: #fff;
  206. font-size: 14px;
  207. z-index: 1000;
  208. padding-top: 15vh;
  209. .cookie-dialog-wrap {
  210. border-radius: 5px;
  211. background-color: rgba(#000, 0.7);
  212. width: 25%;
  213. min-width: 350px;
  214. padding: 40px 60px;
  215. // position: absolute;
  216. // left: 50%;
  217. // top: 50%;
  218. // transform: translate(-50%, -50%);
  219. width: 450px;
  220. margin: 0 auto;
  221. text-align: center;
  222. .cookie-dialog-title {
  223. font-size: 20px;
  224. }
  225. .cookie-dialog-content {
  226. line-height: 1.6;
  227. text-align: left;
  228. padding: 20px 0 30px;
  229. }
  230. .btn {
  231. font-size: 16px;
  232. border: none;
  233. color: #fff;
  234. padding: 5px 10px;
  235. margin: 0 5px;
  236. cursor: pointer;
  237. font-size: 16px !important;
  238. width: 140px;
  239. padding: 10px 0;
  240. background-color: rgba(0, 0, 0, 0);
  241. border: 1px solid #fff;
  242. &:nth-of-type(2) {
  243. background-color: #fff;
  244. color: #222;
  245. }
  246. }
  247. }
  248. }
  249. </style>