<!-- import CSS --> <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"> <!-- import Vue before Element --> <script src="https://unpkg.com/vue/dist/vue.js"></script> <!-- import JavaScript --> <script src="https://unpkg.com/element-ui/lib/index.js"></script> <!-- jquery --> <script src="https://ajax.aspnetcdn.com/ajax/jquery/jquery-3.5.1.min.js"></script>
<div class="store-login" id="app"> <!-- 背景 --> <div class="bg-login"> <li> <img src="./img/bg1.jpg"> </li> <li> <img src="./img/bg2.jpg"> </li> <li> <img src="./img/bg4.jpg"> </li> <li> <img src="./img/bg3.jpg"> </li> </div> <div class="login-s"> <!-- 登陸表單 --> <el-form :model="loginForm" ref="LoginFormRef" :rules="loginFormRules" label-width="0px" class="login_form"> <!-- 用戶名 --> <el-form-item prop="username"> <el-input v-model="loginForm.username" prefix-icon="iconfont icon-user"></el-input> </el-form-item> <!-- 密碼 --> <el-form-item prop="password"> <el-input type="password" v-model="loginForm.password" prefix-icon="iconfont icon-3702mima"></el-input> </el-form-item> <!-- 按鈕 --> <el-form-item class="btns"> <el-button type="primary" @click="login">登陸</el-button> <el-button type="info" @click="resetLoginForm">重置</el-button> </el-form-item> </el-form> </div> </div>
<script> new Vue({ el: '#app', data: function() { return { //數據綁定 index: 3, show: { diplay: 'blok', }, loginForm: { username: 'admin', password: '123456' }, //表單驗證規則 loginFormRules: { username: [{ required: true, message: '請輸入登陸名', trigger: 'blur' }, { min: 3, max: 10, message: '登陸名長度在 3 到 10 個字符', trigger: 'blur' } ], password: [{ required: true, message: '請輸入密碼', trigger: 'blur' }, { min: 6, max: 15, message: '密碼長度在 6 到 15 個字符', trigger: 'blur' } ] } } }, methods: { //添加表單重置方法 resetLoginForm() { //this=>當前組件對象,其中的屬性$refs包含了設置的表單ref // console.log(this) this.$refs.LoginFormRef.resetFields() }, login() { //點擊登陸的時候先調用validate方法驗證表單內容是否有誤 this.$refs.LoginFormRef.validate(async valid => { console.log(this.loginFormRules) //若是valid參數爲true則驗證經過 if (!valid) { return } //發送請求進行登陸 const { data: res } = await this.$http.post('login', this.loginForm) // console.log(res); if (res.meta.status !== 200) { return this.$message.error('登陸失敗:' + res.meta.msg) //console.log("登陸失敗:"+res.meta.msg) } this.$message.success('登陸成功') console.log(res) //保存token window.sessionStorage.setItem('token', res.data.token) // 導航至/home this.$router.push('/home') }) }, changBg() { // alert(11); // const bglogin = document.getElementsByClassName("bg-login"); // console.log(bglogin); if (this.index === 0) { this.index = 3; } else { this.index = this.index - 1; } $(".bg-login>li:eq(" + this.index + ")").fadeIn("3000").siblings().fadeOut("3000"); console.log(this.index); } }, created() { setInterval(this.changBg, 7000); } }) </script>
<style type="text/css"> *{ padding: 0; margin: 0; } body,html { width: 100%; height: 100%; } .store-login { background-color: white; height: 100%; position: relative; } .bg-login { /*background: url("../../public/img/3Dbg01.jpg") no-repeat;*/ /*background-size: 100% 100%;*/ position: relative; height: 100%; opacity: 0.8; z-index: 1; } .bg-login > li { list-style: none; /*display: none;*/ position: relative; width: 100%; height: 100%; position: absolute; } .bg-login > li > img { width: 100%; height: 100%; opacity: 0.9; transition: ease .5s; } .login-s { position: absolute; width: 350px; height: 400px; background-color: rgba(0, 0, 0, 0.3); top: 35%; left: 50%; transform: translate(-50%, -50%); border-radius: 8px; z-index: 2; box-shadow: 10px 10px 20px 0px rgba(0, 0, 0, 0.7); text-align: center; } .login_form { position: relative; top: 50%; left: 50%; transform: translate(-50%, -50%); padding: 0 30px; } </style>
預覽地址:javascript
我的學習,內容簡略css