Vue_shop学习14:登录组件 登录按钮的预校验是否发送请求

发起请求的包 axios使前需要导入

// 导入发起请求的包
import axios from 'axios'
// 设置请求基地址
axios.defaults.baseURL = 'http://127.0.0.1:8888/api/private/v1/'
// 挂载到vue原型对象上
Vue.prototype.$http = axios

基地址根据,接口api调用的 


此时 需要确保服务器接口可以使用

     login(){
                this.$refs.loginFormRef.validate((valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    this.$http.post('login',this.loginForm)
                })
            }

此时打开mysql数据库

 

 启动

此时运行成功 

       login(){
                this.$refs.loginFormRef.validate((valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const result=this.$http.post('login',this.loginForm)
                    console.log(result)//
                })
            }

请求返回结果是promise.我们可以使用await简化结果 await只有用在被async修饰的方法中

      login(){
                this.$refs.loginFormRef.validate(async(valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const result= await this.$http.post('login',this.loginForm)
                    console.log(result)//
                })
            }

输出是具体的响应对象 , 6个属性是axios封装好的,data是服务器返回的真实数据


使用{}解构赋值出来并且重命名我们需要的数据

        login(){
                this.$refs.loginFormRef.validate(async(valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const {data:res}= await this.$http.post('login',this.loginForm)
                    console.log(res)//
                })
            }
        },

<template>
    <div class="login_container">
        <!-- 登录盒子布局 -->
        <div class="login_box">
            <!-- 头像布局 -->
            <div class="avatar_box">
                <img src="../assets/a1.png" alt="">
            </div>
            <!-- 表单布局 -->
            <!-- label-width文本框顶端对齐 -->
            <el-form ref="loginFormRef" :model="loginForm" :rules="loginFormRules" label-width="0px" class="login_form">
                <!-- 用户名 -->
                <el-form-item prop="username">
                    <el-input  put v-model="loginForm.username" prefix-icon="iconfont
                        icon-yonghus"></el-input>
                </el-form-item>
                <!-- 密码 -->
                <el-form-item prop="password">
                    <el-input v-model="loginForm.password" prefix-icon="iconfont
                        icon-mima" type="password"></el-input>
                </el-form-item>
                <!-- 按钮区域 -->
                <el-form-item class="btns">
                    <el-button type="success" @click="login" round>登录</el-button>
                    <el-button type="danger"  @click="resetLoginForm" round>重置</el-button>
                </el-form-item>
            </el-form>
        </div>
    </div>
</template>
<script>
    export default {
        data() {
            return {
                loginForm: {//这是登录表单的数据绑定对象
                    //数据属性
                    username: '',
                    password: ''

                },
                loginFormRules: {//这是登录表单的数据验证规则对象
                    username: [
                        { required: true, message: '请输入用户名称', trigger: 'blur' },
                        { min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }
                    ],//验证用户名是否合法
                    password: [
                        { required: true, message: '请输入密码', trigger: 'blur' },
                        { min: 3, max: 6, message: '长度在 3 到 6 个字符', trigger: 'blur' }
                    ]//验证密码是否合法

                }
            }
        },
        methods:{
            //点击重置按钮,重装
            resetLoginForm(){
               this.$refs.loginFormRef.resetFields()
            },
            login(){
                this.$refs.loginFormRef.validate(async(valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const {data:res}= await this.$http.post('login',this.loginForm)
                    console.log(res)//
                })
            }
        },

    }
</script>
<style lang="less" scoped>
    .login_container {
        background-color: #2b4b6b;
        height: 100%;
    }

    .login_box {
        width: 450px;
        height: 300px;
        background-color: #fff;
        border-radius: 3px;
        /*圆角边框 */
        /* 居中 */
        position: absolute;
        /*则向相当于div进行定位*/
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }

    .avatar_box {
        height: 130px;
        width: 130px;
        border: 4px solid orange;
        border-radius: 50%;
        padding: 5px;
        box-shadow: 0 0 10px #eee;
        /* 移动位置 居中*/
        position: absolute;
        left: 50%;
        transform: translate(-50%, -50%);
        background-color: #fff;

        img {
            width: 100%;
            height: 100%;
            /* 图片圆角边框 */
            border-radius: 50%;
            box-shadow: 0 0 5px #2b4b6b;
            /* background-color: yellow; 如果图片很小 +背景色 */
        }

    }

    /* 表单在页面底部 */
    .login_form {
        position: absolute;
        width: 100%;
        bottom: 0;
        padding: 0 20px;
        /* 不然会溢出 */
        box-sizing: border-box;

    }

    /* 按钮在页面底部 */
    .btns {
        display: flex;
        justify-content: flex-end;
    }
</style>

对是否成功登录进行判断

    login(){
                this.$refs.loginFormRef.validate(async(valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const {data:res}= await this.$http.post('login',this.loginForm)
                    if(res.meta.status!=200) return console.log('登录失败')
                    console.log('登录成功')//
                })
            }

 使用admin 123456登录成功

<template>
    <div class="login_container">
        <!-- 登录盒子布局 -->
        <div class="login_box">
            <!-- 头像布局 -->
            <div class="avatar_box">
                <img src="../assets/a1.png" alt="">
            </div>
            <!-- 表单布局 -->
            <!-- label-width文本框顶端对齐 -->
            <el-form ref="loginFormRef" :model="loginForm" :rules="loginFormRules" label-width="0px" class="login_form">
                <!-- 用户名 -->
                <el-form-item prop="username">
                    <el-input  put v-model="loginForm.username" prefix-icon="iconfont
                        icon-yonghus"></el-input>
                </el-form-item>
                <!-- 密码 -->
                <el-form-item prop="password">
                    <el-input v-model="loginForm.password" prefix-icon="iconfont
                        icon-mima" type="password"></el-input>
                </el-form-item>
                <!-- 按钮区域 -->
                <el-form-item class="btns">
                    <el-button type="success" @click="login" round>登录</el-button>
                    <el-button type="danger"  @click="resetLoginForm" round>重置</el-button>
                </el-form-item>
            </el-form>
        </div>
    </div>
</template>
<script>
    export default {
        data() {
            return {
                loginForm: {//这是登录表单的数据绑定对象
                    //数据属性
                    username: '',
                    password: ''

                },
                loginFormRules: {//这是登录表单的数据验证规则对象
                    username: [
                        { required: true, message: '请输入用户名称', trigger: 'blur' },
                        { min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }
                    ],//验证用户名是否合法
                    password: [
                        { required: true, message: '请输入密码', trigger: 'blur' },
                        { min: 3, max: 6, message: '长度在 3 到 6 个字符', trigger: 'blur' }
                    ]//验证密码是否合法

                }
            }
        },
        methods:{
            //点击重置按钮,重装
            resetLoginForm(){
               this.$refs.loginFormRef.resetFields()
            },
            login(){
                this.$refs.loginFormRef.validate(async(valid)=>{//(valid)种的()可以省略 因为只有一个形参
                   if(!valid) return;//false发起请求失败
                   //url 数据(前面双向绑定的数据)
                    const {data:res}= await this.$http.post('login',this.loginForm)
                    if(res.meta.status!=200) return console.log('登录失败')
                    console.log('登录成功')//
                })
            }
        },

    }
</script>
<style lang="less" scoped>
    .login_container {
        background-color: #2b4b6b;
        height: 100%;
    }

    .login_box {
        width: 450px;
        height: 300px;
        background-color: #fff;
        border-radius: 3px;
        /*圆角边框 */
        /* 居中 */
        position: absolute;
        /*则向相当于div进行定位*/
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }

    .avatar_box {
        height: 130px;
        width: 130px;
        border: 4px solid orange;
        border-radius: 50%;
        padding: 5px;
        box-shadow: 0 0 10px #eee;
        /* 移动位置 居中*/
        position: absolute;
        left: 50%;
        transform: translate(-50%, -50%);
        background-color: #fff;

        img {
            width: 100%;
            height: 100%;
            /* 图片圆角边框 */
            border-radius: 50%;
            box-shadow: 0 0 5px #2b4b6b;
            /* background-color: yellow; 如果图片很小 +背景色 */
        }

    }

    /* 表单在页面底部 */
    .login_form {
        position: absolute;
        width: 100%;
        bottom: 0;
        padding: 0 20px;
        /* 不然会溢出 */
        box-sizing: border-box;

    }

    /* 按钮在页面底部 */
    .btns {
        display: flex;
        justify-content: flex-end;
    }
</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值