简简单单的SPA项目开发之登录注册(使用axios完成数据交互)

本文介绍了使用axios在SPA项目中实现登录注册的数据交互,包括前端ElementUI框架的引入,Eclipse项目的前置工作,以及解决跨域问题的方法。详细讲解了登录界面布局、this指针污染问题的避免,以及axios的使用示例。
摘要由CSDN通过智能技术生成

目录

一、前置工作

1、将项目导入eclipse中

2、修改db.properties

3、运行项目 

4、接着在前端导入api文件夹

 5、运行其中的树形菜单

6、安装开发模块

7、引入element-ui框架​​​​​​​

二、用户登录界面排版

1、添加视图文件(views)

 2、进入ElementUi官网找到对应的组件

 三、数据交互——axios

①this.$router.push(....)

②axios

 四、this指针污染

五、axios跨域问题

什么是跨域?


一、前置工作

1、将项目导入eclipse中

2、修改db.properties

导入进去之后,记得要修改db.properties里的数据库信息:例如数据库账号数据库表名以及数据库密码

3、运行项目 

 

4、接着在前端导入api文件夹

 5、运行其中的树形菜单

运行结果如图所示则为成功:

6、安装开发模块

运行如下四个命令:注意一定要在该工程的根目录下打开cmd进行运行

npm install element-ui -S        
npm install axios -S        
npm install qs -S
npm install vue-axios -S

如图所示: 

下载完成后会在jackage.json中多出四个依赖,则为成功!

7、引入element-ui框架

  ## 重要的事情说三遍:在指定位置!!!在指定位置!!!在指定位置!!!~~~添加三行代码
 在项目中src目录下找到main.js,并在指定位置添加三行代码(main.js是入口文件,所以在这里引入就行,页面就不用引入了)。

OK,前置工作准备完毕,下面我们将进入用户登录页面的布局吧~


二、用户登录界面排版

需求:完成以下页面布局视觉效果。

  

1、添加视图文件(views)

将登陆界面里的组件【Login.vue】添加在视图文件里

 2、进入ElementUi官网找到对应的组件

官网:https://element.eleme.cn/#/zh-CN

 运行效果如图所示:

添加按钮:用户注册忘记密码

 由于这些布局与我们期望的效果是不同的,所以接下来就需要进行调整代码。

最终【Login.vue】代码块展示:

 <template>
   <div class="login-wrap">
     <el-form :model="ruleForm" ref="ruleForm" label-width="100px" class="demo-ruleForm login-container">
       <el-row>
         <el-col :span="24">
           <div style="text-align: center;" class="grid-content bg-purple-dark">
             <h3>用户登录</h3>
           </div>
         </el-col>
       </el-row>
       <el-form-item label="用户" prop="uname">
         <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
       </el-form-item>
       <el-form-item label="密码" prop="pwd">
         <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
       </el-form-item>
       <el-form-item>
         <el-row>
           <el-col :span="24">
             <div style="text-align: center;" class="grid-content bg-purple-dark">
               <el-button style="width: 100%;" type="primary" @click="submitForm">提交</el-button>
             </div>
           </el-col>
         </el-row>
       </el-form-item>
       <el-form-item>
         <el-row>
           <el-col :span="12">
             <div style="text-align: center;" class="grid-content bg-purple-dark">
               <el-link type="success" @click="toReg">用户注册</el-link>
             </div>
           </el-col>
           <el-col :span="12">
             <div style="text-align: center;" class="grid-content bg-purple-dark">
               <el-link type="warning" @click="">忘记密码</el-link>            </div>
           </el-col>
         </el-row>
       </el-form-item>
     </el-form>
   </div>
 </template>

 <script>
 export default {
   name: 'Login',
   data () {
     return {
       ruleForm:{}
     }
   },
   methods:{
     submitForm() {
       // this.axios 找到的是/api/http.js 文件
       // axios.urls = action --> this.axios.urls找到了 /api/action.js
       // action.js是一个JSON对象,那么就可以取到请求的值
       let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
       this.axios.post(url,this.ruleForm)
         .then(function(resp){//代表成功
           console.log(resp);
         }).catch(function(){//代表失败

         });
     },
     resetForm(){

     },
     toReg(){
       this.$router.push({path:'/Reg'});
     }

   }
 }
 </script>

 <style scoped>
 	.login-wrap {
 		box-sizing: border-box;
 		width: 100%;
 		height: 100%;
 		padding-top: 10%;
 		background-image: url(
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值