vue实现一个登录页面
时间: 2023-10-22 08:20:46 浏览: 27
以下是一个简单的Vue登录页面示例:
```HTML
<template>
<div class="login">
<h1>登录</h1>
<form>
<div class="form-group">
<label for="username">用户名:</label>
<input type="text" id="username" v-model="username" />
</div>
<div class="form-group">
<label for="password">密码:</label>
<input type="password" id="password" v-model="password" />
</div>
<button type="submit" @click.prevent="login">登录</button>
</form>
<div v-if="error" class="error">{{ error }}</div>
</div>
</template>
<script>
export default {
data() {
return {
username: '',
password: '',
error: ''
}
},
methods: {
login() {
// 实现登录逻辑,这里只是一个简单示例
if (this.username === 'admin' && this.password === '123456') {
alert('登录成功')
} else {
this.error = '用户名或密码错误'
}
}
}
}
</script>
<style scoped>
.login {
max-width: 400px;
margin: 0 auto;
padding: 20px;
border: 1px solid #ccc;
border-radius: 5px;
}
.form-group {
margin-bottom: 10px;
}
label {
display: inline-block;
width: 100px;
}
input[type="text"],
input[type="password"] {
width: 200px;
border: 1px solid #ccc;
border-radius: 5px;
padding: 5px;
}
button[type="submit"] {
background-color: #4CAF50;
color: white;
border: none;
border-radius: 5px;
padding: 10px 20px;
cursor: pointer;
}
button[type="submit"]:hover {
background-color: #45a049;
}
.error {
color: red;
}
</style>
```
在这个示例中,我们使用了Vue的模板语法来构建登录表单,并使用了v-model指令来实现数据的双向绑定。在点击登录按钮时,我们调用了login方法来处理登录逻辑。如果用户名和密码正确,弹出登录成功的提示框;否则,在页面上显示错误信息。
注意,在样式中使用了scoped修饰符,这样可以将样式限制在组件内部,避免样式冲突的问题。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)