优化Vue登录页面:添加背景图片与样式美化

个人名片🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室&am

个人名片

🎓作者简介:java领域优质创作者
🌐个人主页:码农阿豪
📞工作室:新空间代码工作室(提供各种软件服务)
💌个人邮箱:[2435024119@qq]
📱个人微信:15279484656
🌐个人导航网站:www.forff.top
💡座右铭:总有人要赢。为什么不能是我呢?

  • 专栏导航:

码农阿豪系列专栏导航
面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️
Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻
Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡
全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀

目录

  • 优化Vue登录页面:添加背景图片与样式美化
    • 目录
    • 1. 背景与需求分析
    • 2. 技术栈与工具
    • 3. 实现步骤
      • 3.1 添加背景图片
        • 3.1.1 修改HTML结构
        • 3.1.2 添加CSS样式
      • 3.2 优化表单样式
        • 3.2.1 表单容器样式
        • 3.2.2 输入框样式
      • 3.3 调整布局与交互
        • 3.3.1 表单居中显示
        • 3.3.2 按钮样式
    • 4. 完整代码展示
    • 5. 总结与展望

优化Vue登录页面:添加背景图片与样式美化

在现代Web开发中,登录页面是用户与系统交互的第一道门槛。一个美观且功能完善的登录页面不仅能提升用户体验,还能增强用户对系统的信任感。本文将详细介绍如何在一个基于Vue.js和Element UI的登录页面中添加背景图片,并对现有代码进行优化,使其更加美观和实用。

目录

  1. 背景与需求分析
  2. 技术栈与工具
  3. 实现步骤
    • 添加背景图片
    • 优化表单样式
    • 调整布局与交互
  4. 完整代码展示
  5. 总结与展望

1. 背景与需求分析

登录页面是用户进入系统的入口,其设计直接影响用户的第一印象。一个优秀的登录页面应具备以下特点:

  • 美观:背景图片、配色方案等视觉元素应和谐统一。
  • 易用:输入框、按钮等交互元素应清晰易用。
  • 响应式:页面应适配不同设备和屏幕尺寸。

在本文中,我们将基于一个现有的Vue.js登录页面,添加背景图片,并优化其样式和布局。


2. 技术栈与工具

本文使用的技术栈和工具包括:

  • Vue.js:前端框架,用于构建用户界面。
  • Element UI:基于Vue.js的UI组件库,提供丰富的UI组件。
  • SCSS:CSS预处理器,用于编写更灵活的样式。
  • Webpack:模块打包工具,用于构建和打包项目。

3. 实现步骤

3.1 添加背景图片

首先,我们需要在登录页面的容器中添加背景图片。以下是具体步骤:

3.1.1 修改HTML结构

在Vue组件的模板部分,找到 .login-container 容器,并确保其覆盖整个页面:

<template>
  <div class="login-container">
    <!-- 登录表单内容 -->
  </div>
</template>
3.1.2 添加CSS样式

在样式部分,为 .login-container 添加背景图片,并设置其覆盖整个页面:

.login-container {
  min-height: 100vh; // 使用视口高度
  width: 100%;
  background-image: url('~@/assets/login-bg.jpg'); // 替换为你的背景图片路径
  background-size: cover; // 背景图片覆盖整个容器
  background-position: center; // 背景图片居中
  display: flex;
  justify-content: center;
  align-items: center;
}

3.2 优化表单样式

为了让表单在背景图片上更加清晰,我们需要调整表单的背景色、边框和阴影等样式。

3.2.1 表单容器样式

.login-form 添加半透明的背景色和圆角边框:

.login-form {
  width: 520px;
  padding: 40px;
  background-color: rgba(45, 58, 75, 0.8); // 半透明背景色
  border-radius: 8px; // 圆角边框
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); // 阴影效果
}
3.2.2 输入框样式

调整输入框的背景色和光标颜色,确保在深色背景下输入内容清晰可见:

.login-container .el-input input {
  background: transparent;
  border: 0px;
  -webkit-appearance: none;
  border-radius: 0px;
  padding: 12px 5px 12px 15px;
  color: #fff; // 输入文字颜色
  height: 47px;
  caret-color: #fff; // 光标颜色

  &:-webkit-autofill {
    box-shadow: 0 0 0px 1000px rgba(45, 58, 75, 0.8) inset !important;
    -webkit-text-fill-color: #fff !important;
  }
}

3.3 调整布局与交互

为了让页面更加友好,我们需要调整布局和交互细节。

3.3.1 表单居中显示

使用Flexbox布局将表单居中显示:

.login-container {
  display: flex;
  justify-content: center;
  align-items: center;
}
3.3.2 按钮样式

调整登录按钮的样式,使其更加醒目:

.el-button--primary {
  width: 100%;
  margin-bottom: 30px;
  background-color: #409EFF; // 按钮背景色
  border-color: #409EFF; // 按钮边框色
}

4. 完整代码展示

以下是优化后的完整代码:

<template>
  <div class="login-container">
    <el-form ref="loginForm" :model="loginForm" :rules="loginRules" class="login-form" auto-complete="on" label-position="left">

      <div class="title-container">
        <h3 class="title">就业信息管理系统</h3>
      </div>

      <el-form-item prop="username">
        <span class="svg-container">
          <svg-icon icon-class="user" />
        </span>
        <el-input
          ref="username"
          v-model="loginForm.username"
          placeholder="Username"
          name="username"
          type="text"
          tabindex="1"
          auto-complete="on"
        />
      </el-form-item>

      <el-form-item prop="password">
        <span class="svg-container">
          <svg-icon icon-class="password" />
        </span>
        <el-input
          :key="passwordType"
          ref="password"
          v-model="loginForm.password"
          :type="passwordType"
          placeholder="Password"
          name="password"
          tabindex="2"
          auto-complete="on"
          @keyup.enter.native="handleLogin"
        />
        <span class="show-pwd" @click="showPwd">
          <svg-icon :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'" />
        </span>
      </el-form-item>

      <el-button :loading="loading" type="primary" style="width:100%;margin-bottom:30px;" @click.native.prevent="handleLogin">Login</el-button>

    </el-form>
  </div>
</template>

<script>
import { validUsername } from '@/utils/validate'

export default {
  name: 'Login',
  data() {
    const validateUsername = (rule, value, callback) => {
      if (!validUsername(value)) {
        callback(new Error('请输入正确的用户名'))
      } else {
        callback()
      }
    }
    const validatePassword = (rule, value, callback) => {
      if (value.length < 6) {
        callback(new Error('密码不能少于 6 位'))
      } else {
        callback()
      }
    }
    return {
      loginForm: {
        username: 'admin',
        password: '111111'
      },
      loginRules: {
        username: [{ required: true, trigger: 'blur', validator: validateUsername }],
        password: [{ required: true, trigger: 'blur', validator: validatePassword }]
      },
      loading: false,
      passwordType: 'password',
      redirect: undefined
    }
  },
  watch: {
    $route: {
      handler: function(route) {
        this.redirect = route.query && route.query.redirect
      },
      immediate: true
    }
  },
  methods: {
    showPwd() {
      if (this.passwordType === 'password') {
        this.passwordType = ''
      } else {
        this.passwordType = 'password'
      }
      this.$nextTick(() => {
        this.$refs.password.focus()
      })
    },
    handleLogin() {
      this.$refs.loginForm.validate(valid => {
        if (valid) {
          this.loading = true
          this.$store.dispatch('user/login', this.loginForm).then(() => {
            this.$router.push({ path: this.redirect || '/' })
            this.loading = false
          }).catch(() => {
            this.loading = false
          })
        } else {
          console.log('error submit!!')
          return false
        }
      })
    }
  }
}
</script>

<style lang="scss">
$bg: rgba(45, 58, 75, 0.8);
$light_gray: #fff;
$cursor: #fff;

@supports (-webkit-mask: none) and (not (cater-color: $cursor)) {
  .login-container .el-input input {
    color: $cursor;
  }
}

.login-container {
  .el-input {
    display: inline-block;
    height: 47px;
    width: 85%;

    input {
      background: transparent;
      border: 0px;
      -webkit-appearance: none;
      border-radius: 0px;
      padding: 12px 5px 12px 15px;
      color: $light_gray;
      height: 47px;
      caret-color: $cursor;

      &:-webkit-autofill {
        box-shadow: 0 0 0px 1000px $bg inset !important;
        -webkit-text-fill-color: $cursor !important;
      }
    }
  }

  .el-form-item {
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(0, 0, 0, 0.1);
    border-radius: 5px;
    color: #454545;
  }
}
</style>

<style lang="scss" scoped>
$dark_gray: #889aa4;
$light_gray: #eee;

.login-container {
  min-height: 100vh;
  width: 100%;
  background-image: url('~@/assets/login-bg.jpg');
  background-size: cover;
  background-position: center;
  display: flex;
  justify-content: center;
  align-items: center;

  .login-form {
    width: 520px;
    padding: 40px;
    background-color: $bg;
    border-radius: 8px;
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  }

  .svg-container {
    padding: 6px 5px 6px 15px;
    color: $dark_gray;
    vertical-align: middle;
    width: 30px;
    display: inline-block;
  }

  .title-container {
    position: relative;

    .title {
      font-size: 26px;
      color: $light_gray;
      margin: 0px auto 40px auto;
      text-align: center;
      font-weight: bold;
    }
  }

  .show-pwd {
    position: absolute;
    right: 10px;
    top: 7px;
    font-size: 16px;
    color: $dark_gray;
    cursor: pointer;
    user-select: none;
  }
}
</style>

5. 总结与展望

通过本文的优化,我们成功地为登录页面添加了背景图片,并优化了表单的样式和布局。这些改进不仅提升了页面的美观度,还增强了用户的交互体验。

未来,我们可以进一步优化以下方面:

  • 响应式设计:确保页面在不同设备上都能良好显示。
  • 动画效果:添加一些过渡动画,提升页面的动态效果。
  • 安全性:增强登录表单的安全性,例如添加验证码功能。

希望本文对你有所帮助!如果有任何问题或建议,欢迎留言讨论。

发布者:admin,转转请注明出处:http://www.yc00.com/web/1754846646a5206353.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信