这是个 全新 的Vue项目,引入了ElementUI
&nbs p; 将App.vue里的内容干掉,剩如下
然后下面的三个文件也可以删掉了
在views文件下新建Lo gin .vue组件
到router目录下的index.js
那么现在的流程大概是这样子的
启动
写 登陆页面
<template> <div> <el-form :ref="form" :model=" LOG inForm" class="loginCont ai ner"> <h3 class="loginT IT le">系统登录</h3> <!-- auto- complete ="false"自动补全 --> <el-form -i tem label=""> <el-input ty PE ="text" auto-complete="false" v-model="loginForm.usern am e" placeholder="请输入用户名"></el-input> </el-form-item> <el-form-item label=""> <el-input type="text" auto-complete="false" v-model="loginForm.password" placeholder="请输入密码"></el-input> </el-form-item> <el-form-item label=""> <el-input type="text" auto-complete="false" v-model="loginForm.code" placeholder="点击图片更换验证码" style="width:250px ;m arg in-right: 5px;"></el-input> < img :src="captchaUrl"/> </el-form-item> <el-checkbox v-model="checked" class="loginRemeber">记住我</el-checkbox> <el-button type=" Primary " style="width:100%">登录</el-button> </el-form> </div> </template> <script> export default { name:"Login", data(){ return{ captchaUrl:'',//验证码图片链接 loginForm:{ username:'admin', password:'123456', code:'1234' }, checked:true } } } </script> <style> .loginContainer{ border-radius: 15px; background-clip: padding-box; margin:180px auto; width:350px; padding: 15px 35px 15px 35px; background: # a8dad5; border:1px solid #eaeaea; box -s hadow: 0 0 25px #cac6c6; } .loginTitle{ margin: 0px auto 40px auto; text-align: center ; } .loginRemeber{ text-align: left; margin:0px 0px 15px 0px; } </style>
给登录按钮添加 点击事件
添加方法
添加表单校验 暂时先吧:ref="form"去掉
校验的username,password,code需要和上面的对应上 需要加 PR op属性
测试,校验规则是存在的,但是出现的问题是点击表单还是 生效 的
在点击登录时候添加表单校验
会自动根据我们自己定义的校验规则来校验,还是将用户名长度改成5位好了
用ElementUI的showMessage
效果如下
接下来需要发送axios请求
安装axios
安装完成,可以 在P ackage. json文件 看到
组件里引入
这里我随便建个 后端 ,先进行演示,会出现跨域现象,这里跨域先不讲
看下返回的信息里有什么
<template> <div> <el-form :rules="rules" ref="form" :model="loginForm" class="loginContainer"> <h3 class="loginTitle">系统登录</h3> <!-- auto-complete="false"自动补全 --> <el-form-item prop="username"> <el-input type="text" auto-complete="false" v-model="loginForm.username" placeholder="请输入用户名"></el-input> </el-form-item> <el-form-item prop="password"> <el-input type="text" auto-complete="false" v-model="loginForm.password" placeholder="请输入密码"></el-input> </el-form-item> <el-form-item prop="code"> <el-input type="text" auto-complete="false" v-model="loginForm.code" placeholder="点击图片更换验证码" style="width:250px;margin-right: 5px;"></el-input> <img :src="captchaUrl"/> </el-form-item> <el-checkbox v-model="checked" class="loginRemeber">记住我</el-checkbox> <el-button type="primary" style="width:100%" @click="s ub mitLogin">登录</el-button> </el-form> </div> </template> <script> import axios From 'axios' e xp ort default { name:"Login", data(){ return{ captchaUrl:'',//验证码图片链接 loginForm:{ username:'admin', password:'123456', code:'1234' }, checked:true, rules:{ username:[ {requi red :true,message:'请输入用户名',trigger:'blur'}, {min:5,max:12,message:'用户名长度6到12位',trigger:'blur'} ], password:[ {required:true,message:'请输入密码',trigger:'blur'}, {min:6,max:12,message:'密码长度6到12位',trigger:'blur'} ], code:[ {required:true,message:'请输入验证码',trigger:'blur'}, {min:4,max:4,message:'验证码长度4位',trigger:'blur'} ], } } }, methods:{ submitLogin(){ this.$refs.form.validate((valid)=>{ if(valid){ axios.post('http://localhost:8081/demo',{username:"xxx",password:"123456",code:"1234"}).then((res)=>{ console.log(res) }) }else{ this.$message.error('请输入正确格式') return false } }) } } } </script> <style> .loginContainer{ border-radius: 15px; background-clip: padding-box; margin:180px auto; width:350px; padding: 15px 35px 15px 35px; background: #a8dad5; border:1px solid #eaeaea; box-shadow: 0 0 25px #cac6c6; } .loginTitle{ margin: 0px auto 40px auto; text-align: center; } .loginRemeber{ text-align: left; margin:0px 0px 15px 0px; } </style>
总结
到此这篇关于Vue项目创建首页发送axios请求的 文章 就介绍到这了,更多相关Vue创建首页发送axios请求内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章: Vue.js实战之使用Vuex + axios发送请求详解 VUE axios发送跨域请求需要注意的问题 在vue项目中使用axios发送post请求出现400错误的解决 vue cli3 项目中如何使用axios发送post请求 Vue使用axios发送请求并实现简单封装的示例详解
总结
以上是 为你收集整理的 Vue项目创建首页发送axios请求的方法实例 全部内容,希望文章能够帮你解决 Vue项目创建首页发送axios请求的方法实例 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于Vue项目创建首页发送axios请求的方法实例的详细内容...