Login.vue 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <style lang="scss">
  2. @import '../style/_base.scss';
  3. .login{
  4. height: 100vh;
  5. min-height: 450px;
  6. background: #1F315D;
  7. position: relative;
  8. .login-div{
  9. width:520px;
  10. height:448px;
  11. background:#FFFFFF;
  12. box-shadow:0px 12px 24px 0px rgba(0,0,0,0.24);
  13. border-radius:8px;
  14. position: absolute;
  15. top: 0;
  16. bottom: 0;
  17. left: 0;
  18. right: 0;
  19. margin: auto;
  20. padding:48px 75px;
  21. h1{
  22. text-align: center;
  23. margin-bottom: 40px;
  24. font-size: 28px;
  25. }
  26. .input_div{
  27. position: relative;
  28. margin-bottom: 12px;
  29. input{
  30. padding-left: 80px;
  31. outline: none;
  32. background:rgba(242,245,247,1);
  33. border-radius:8px;
  34. border:1px solid rgba(238,238,238,1);
  35. display: block;
  36. height: 54px;
  37. width: 100%;
  38. font-size: 16px;
  39. }
  40. label{
  41. color: #222;
  42. font-size: 16px;
  43. position: absolute;
  44. left: 16px;
  45. top:16px;
  46. z-index: 99;
  47. }
  48. }
  49. .code{
  50. input{
  51. width: 250px;
  52. }
  53. img{
  54. width: 108px;
  55. height: 54px;
  56. float: right;
  57. background-origin: 1px solid red;
  58. }
  59. }
  60. .login-btn{
  61. background: #066fe6;
  62. width: 100%;
  63. height: 54px;
  64. margin-top: 36px;
  65. font-size: 18px;
  66. color: #FFF;
  67. font-weight: 600;
  68. border:none;
  69. border-radius: 8px;
  70. }
  71. }
  72. .footer{
  73. position: fixed;
  74. width: 100%;
  75. bottom: 10px;
  76. left:0;
  77. z-index: 9;
  78. text-align: center;
  79. color:#fff;
  80. font-size: 14px;
  81. }
  82. }
  83. </style>
  84. <template>
  85. <div class="login">
  86. <div class="login-div">
  87. <h1>期刊微信公众号管理系统</h1>
  88. <form>
  89. <div class="input_div">
  90. <label>账号</label>
  91. <input type="text" v-model="logindata.username" placeholder="请输入用户名">
  92. </div>
  93. <div class="input_div">
  94. <label>密&nbsp;&nbsp;码</label>
  95. <input type="password" v-model="logindata.password" placeholder="请输入密码">
  96. </div>
  97. <div class="input_div code">
  98. <img @click="getCode" :src="code" alt="">
  99. <label>图形码</label>
  100. <input type="text" v-model="logindata.imgcode" placeholder="请输入验证码">
  101. </div>
  102. <el-button @click="login" @keyup.enter="login" class="login-btn" type="primary">登 录</el-button>
  103. </form>
  104. </div>
  105. <p class="footer">Copyright © {{copyrightdate}} 中国科学院 版权所有</p>
  106. </div>
  107. </template>
  108. <script>
  109. export default {
  110. name: 'login',
  111. data(){
  112. return{
  113. tp:'xt',
  114. code:'',
  115. logindata:{
  116. username:'',
  117. password:'',
  118. imgcode_id:'',
  119. imgcode:'',
  120. utype:2
  121. },
  122. copyrightdate:new Date().getFullYear()
  123. }
  124. },
  125. methods:{
  126. keyupEnter(){
  127. document.onkeydown = e =>{
  128. if (e.keyCode === 13) {
  129. console.log('enter')
  130. this.login()
  131. }
  132. }
  133. },
  134. login(){
  135. let parms=this.logindata;
  136. console.log(parms)
  137. this.$api.login(parms).then((res)=>{
  138. let data=res.data
  139. if(res.data.code == 0){
  140. // window.location.hash='/index/index';
  141. window.location.hash='/message/message';
  142. }else{
  143. this.$message.error(res.data.message);
  144. }
  145. })
  146. },
  147. getCode(){
  148. this.$api.getCode().then(res=>{
  149. this.code=res.data.data.imgcode
  150. this.logindata.imgcode_id=res.data.data.imgcode_id
  151. })
  152. }
  153. },
  154. created(){
  155. this.getCode()
  156. }
  157. }
  158. </script>