UserLayout.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <template>
  2. <div id="userLayout" :class="['user-layout-wrapper', device]">
  3. <div class="container">
  4. <div class="top">
  5. <div class="header">
  6. <a href="/">
  7. <img src="~@/assets/logo.png" class="logo" alt="logo">
  8. <span class="title">Guns快速开发平台</span>
  9. </a>
  10. </div>
  11. <div class="desc">
  12. Guns 是华夏最具影响力的 Web 快速开发平台
  13. </div>
  14. </div>
  15. <route-view></route-view>
  16. <div class="footer">
  17. <div class="links">
  18. <a href="_self">帮助</a>
  19. <a href="_self">隐私</a>
  20. <a href="_self">条款</a>
  21. </div>
  22. <div class="copyright">
  23. Copyright © 2020 <a target="_blank" href="https://www.stylefeng.cn/">stylefeng</a> All rights reserved. Guns-Seperation v1.1.0
  24. </div>
  25. </div>
  26. </div>
  27. </div>
  28. </template>
  29. <script>
  30. import RouteView from './RouteView'
  31. import { mixinDevice } from '@/utils/mixin'
  32. export default {
  33. name: 'UserLayout',
  34. components: { RouteView },
  35. mixins: [mixinDevice],
  36. data () {
  37. return {}
  38. },
  39. mounted () {
  40. document.body.classList.add('userLayout')
  41. },
  42. beforeDestroy () {
  43. document.body.classList.remove('userLayout')
  44. }
  45. }
  46. </script>
  47. <style lang="less" scoped>
  48. #userLayout.user-layout-wrapper {
  49. height: 100%;
  50. &.mobile {
  51. .container {
  52. .main {
  53. max-width: 368px;
  54. width: 98%;
  55. }
  56. }
  57. }
  58. .container {
  59. width: 100%;
  60. min-height: 100%;
  61. background-color: #ffffff;
  62. background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 900'%3E%3Cpolygon fill='%2340a7cc' points='957 450 539 900 1396 900'/%3E%3Cpolygon fill='%23c6dbe1' points='957 450 872.9 900 1396 900'/%3E%3Cpolygon fill='%2350a7c5' points='-60 900 398 662 816 900'/%3E%3Cpolygon fill='%23c0d7da' points='337 900 398 662 816 900'/%3E%3Cpolygon fill='%235fa6be' points='1203 546 1552 900 876 900'/%3E%3Cpolygon fill='%23bad3d4' points='1203 546 1552 900 1162 900'/%3E%3Cpolygon fill='%236fa6b8' points='641 695 886 900 367 900'/%3E%3Cpolygon fill='%23b3cfcd' points='587 900 641 695 886 900'/%3E%3Cpolygon fill='%237ea5b1' points='1710 900 1401 632 1096 900'/%3E%3Cpolygon fill='%23adcbc7' points='1710 900 1401 632 1365 900'/%3E%3Cpolygon fill='%238ea5aa' points='1210 900 971 687 725 900'/%3E%3Cpolygon fill='%23a7c7c0' points='943 900 1210 900 971 687'/%3E%3C/svg%3E");
  63. background-attachment: fixed;
  64. background-size: cover;
  65. padding: 110px 0 144px;
  66. position: relative;
  67. a {
  68. text-decoration: none;
  69. }
  70. .top {
  71. text-align: center;
  72. .header {
  73. height: 44px;
  74. line-height: 44px;
  75. .badge {
  76. position: absolute;
  77. display: inline-block;
  78. line-height: 1;
  79. vertical-align: middle;
  80. margin-left: -12px;
  81. margin-top: -10px;
  82. opacity: 0.8;
  83. }
  84. .logo {
  85. height: 44px;
  86. vertical-align: top;
  87. margin-right: 16px;
  88. border-style: none;
  89. }
  90. .title {
  91. font-size: 33px;
  92. color: rgba(0, 0, 0, .85);
  93. font-family: Avenir, 'Helvetica Neue', Arial, Helvetica, sans-serif;
  94. font-weight: 600;
  95. position: relative;
  96. top: 2px;
  97. }
  98. }
  99. .desc {
  100. font-size: 14px;
  101. color: rgba(0, 0, 0, 0.45);
  102. margin-top: 12px;
  103. margin-bottom: 40px;
  104. }
  105. }
  106. .main {
  107. min-width: 260px;
  108. width: 368px;
  109. margin: 0 auto;
  110. }
  111. .footer {
  112. position: absolute;
  113. width: 100%;
  114. bottom: 0;
  115. padding: 0 16px;
  116. margin: 48px 0 24px;
  117. text-align: center;
  118. .links {
  119. margin-bottom: 8px;
  120. font-size: 14px;
  121. a {
  122. color: rgba(0, 0, 0, 0.45);
  123. transition: all 0.3s;
  124. &:not(:last-child) {
  125. margin-right: 40px;
  126. }
  127. }
  128. }
  129. .copyright {
  130. color: rgba(0, 0, 0, 0.45);
  131. font-size: 14px;
  132. }
  133. }
  134. }
  135. }
  136. </style>