Vue --- 登陆+注册

目录

1. vue怎么引入和配置使用element-ui框架

2. Vue+ElementUI设计登陆和注册页面

3. 后台交互(axios/qs/vue-axios)

附录一:ES6的语法箭头函数:

箭头函数:

this

练习


目标:vue+elementUI完成注册及登陆


1. vue怎么引入和配置使用element-ui框架

  1.1 使用vue-cli脚手架工具创建一个vue项目
      vue init webpack 项目名(medpro)

  1.2 npm安装elementUI
      cd medpro                                      #进入新建项目的根目录
      npm install element-ui -S               #安装element-ui模块

  ~~~添加三行代码
  1.3 在项目中src目录下找到main.js,并在指定位置添加三行代码(main.js是入口文件,所以在这里引入就行,页面就不用引入了)

      import ElementUI from 'element-ui' //新添加1
      import 'element-ui/lib/theme-chalk/index.css' //新添加2,避免后期打包样式不同,要放在import App from './App';之前


      Vue.use(ElementUI)   //新添加3
 

  1.4 测试
      修改HelloWorld.vue添加elementUI组件查看效果

代码案例: 

-----------登录Login.vue----------
<template>
  <div>
    <h1>登录-{
  {ts}}</h1>
  </div>
</template>

<script>
  export default{
    name:'Login',
    data:function(){
      return{
        ts:new Date().getTime()
      }
    },
    methods:{

    }
  }
</script>

<style>
</style>

-----------注册Register.vue----------
<template>
  <div>
    <h1>注册-{
  {ts}}</h1>
  </div>
</template>

<script>
  export default{
    name:'Register',
    data:function(){
      return{
        ts:new Date().getTime()
      }
    },
    methods:{

    }
  }
</script>

<style>
</style>

-----------router/index.js----------
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'

//登录
import Login from '@/views/Login'
//注册
import Register from '@/views/Register'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/HelloWorld',
      name: 'HelloWorld',
      component: HelloWorld
    },{
      path: '/',
      name: 'Login',
      component: Login
    },{
      path: '/Register',
      name: 'Register',
      component: Register
    }
  ]
})

                                                                    运行效果:

 

2. Vue+ElementUI设计登陆和注册页面

2.1:相关样式见资料“css.txt”

-------------App.vue

<style> 
html,
body {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 0px;
    margin: 0px;
}
#app {
    font-family: "Avenir", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #2c3e50;
    widows: 100%;
    height: 100%;
}
</style>


-------------login.vue
<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}

	.login-container {
		border-radius: 10px;
		margin: 0px auto;
		width: 350px;
		padding: 30px 35px 15px 35px;
		background: #fff;
		border: 1px solid #eaeaea;
		text-align: left;
		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
	}

	.title {
		margin: 0px auto 40px auto;
		text-align: center;
		color: #505458;
	}
</style>

2.2:<style scoped>
        在vue组件中,在style标签上添加scoped属性,以表示它的样式作用于当前模块,很好的实现了样式私有化的目的

2.3:auto-complete="off"
        autocomplete 属性是 HTML5 中的新属性,off-----禁用自动完成(就是没有历史记录)

代码案例: 

---------------Login.vue----------------
<template>
  <div class="login-wrap">
    <el-form class="login-container">
      <h1 class="title">用户登录:</h1>
      <el-form-item>
        <el-input type="text" placeholder="用户账号" v-model="username" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-input type="password" placeholder="用户密码" v-model="password" autocomplete="off"></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="doLogin" style="width: 100%;">登录</el-button>
      </el-form-item>
      <el-row style="text-align: center;margin-top: -10px;">
        <el-link type="primary" @click="toRegister">用户注册</el-link>
        <el-link type="primary">忘记密码</el-link>
      </el-row>
    </el-form>
  </div>
</template>

<script>
  export default {
    name: 'Login',
    data: function() {
      return {
        username: '',
        password: ''
      }
    },
    methods: {
      doLogin:function(){
        let username=this.username;
        let password=this.password;
        /* let params={

        } */
        console.log("username=%s,password=%s",username,password);
      },
      toRegister:function(){
        this.$router.push('/Register');
      }
    }
  }
</script>

<style>
  .login-wrap {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding-top: 10%;
    background-image: url(
  • 15
    点赞
  • 111
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
本文将介绍如何使用Spring Boot、Vue和MyBatis-Plus实现用户登录和注册功能。 1. 创建Spring Boot项目 首先,我们需要创建一个Spring Boot项目。可以使用Spring Initializr来创建基础项目。在创建项目时,需要添加Web、MyBatis、MySQL等依赖项。 2. 配置数据库连接 在src/main/resources/application.properties文件中,添加以下代码来配置数据库连接: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 其中,url、username和password分别是数据库的连接地址、用户名和密码。 3. 创建数据库表 在MySQL数据库中创建一个名为user的表,包含以下字段: ``` id INT(11) NOT NULL AUTO_INCREMENT, username VARCHAR(50) NOT NULL, password VARCHAR(50) NOT NULL, PRIMARY KEY (id) ``` 4. 创建实体类和Mapper接口 创建一个名为User的实体类,并添加以下属性和方法: ``` public class User { private Integer id; private String username; private String password; // getter和setter方法 } ``` 同时,创建一个名为UserMapper的Mapper接口,并添加以下方法: ``` public interface UserMapper extends BaseMapper<User> { User selectByUsername(String username); } ``` 其中,selectByUsername方法用于根据用户名查询用户信息。 5. 创建Service和Controller类 创建一个名为UserService的Service类,并添加以下方法: ``` public interface UserService { User login(String username, String password); boolean register(User user); } ``` 创建一个名为UserController的Controller类,并添加以下方法: ``` @RestController @RequestMapping("/api/user") public class UserController { @Autowired private UserService userService; @PostMapping("/login") public Result<User> login(@RequestBody User user) { User loginUser = userService.login(user.getUsername(), user.getPassword()); if (loginUser != null) { return Result.success(loginUser); } else { return Result.error("用户名或密码错误"); } } @PostMapping("/register") public Result<Boolean> register(@RequestBody User user) { boolean success = userService.register(user); if (success) { return Result.success(true); } else { return Result.error("用户名已存在"); } } } ``` 其中,login方法用于处理用户登录请求,register方法用于处理用户注册请求。 6. 创建Vue项目 使用Vue CLI创建一个名为user-management的Vue项目: ``` vue create user-management ``` 7. 配置请求代理 在vue.config.js文件中,添加以下代码来配置请求代理: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://localhost:8080', changeOrigin: true } } } } ``` 其中,target指定了后端的地址和端口号。 8. 创建登录和注册页面 在src/views目录下,创建Login.vue和Register.vue两个组件,分别用于显示登录和注册页面。在这两个组件中,可以使用axios库来发送请求。 9. 测试 启动后端服务和Vue应用,访问http://localhost:8080和http://localhost:8080/api/user/login可以测试登录功能,访问http://localhost:8080/api/user/register可以测试注册功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值