目录

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

2.修改端口

3. Vue+ElementUI设计页面

4 .axios/qs/vue-axios安装及使用步骤

5.axios提交方式

1.GET提交

2.POST提交

3.vue项目对axios的全局配置

6.登录案例

1. vue怎么引入和配置使用element-ui框架
     1使用vue-cli脚手架工具创建一个vue项目
        vue init webpack xxx

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

3 在项目中src目录下找到main.js,并在指定位置添加三行代码(main.js是入口文件,所以在这里引入就行,页面就不用引入了)
      import Vue from 'vue'
 
      import ElementUI from 'element-ui' //新添加1
      import 'element-ui/lib/theme-chalk/index.css' //新添加2,避免后期打包样式不同,要放在import App from './App';之前
      
      import App from './App'
      import router from './router'

Vue.use(ElementUI)   //新添加3
      Vue.config.productionTip = false

2.修改端口
vue-cli构建的项目,在控制台npm run dev启动后,默认的调试地址是8080端口的但是大部分时候,
        我们都要并行几个项目开发,很有可能已经占用了8080端口,所以就涉及到如何去更改调试地址的端口号了
        config --> index.js  
        dev: {
          // Paths
          assetsSubDirectory: 'static',
          assetsPublicPath: '/',
          proxyTable: {},
          host: 'localhost', 
          port: 8083,       // 在这里修改端口号
          autoOpenBrowser: false,
          errorOverlay: true,
          notifyOnErrors: true,
        },

3. Vue+ElementUI设计页面
 https://element.eleme.cn/#/zh-CN

4 .axios/qs/vue-axios安装及使用步骤
qs
      qs.js它是一个url参数转化的js库。用法就两个:
      var obj = qs.parse('a=b&c=d');  //将URL解析成对象的形式:{a:'b',c:'d'}
      var str = qs.stringify(obj);    //将对象 序列化成URL的形式,以&进行拼接:a=b&c=d'

vue-axios
      vue-axios是在axios基础上扩展的插件,在Vue.prototype原型上扩展了$http等属性,可以更加方便的使用axios

1.安装
      npm install axios -S
      npm install qs -S  
      npm install vue-axios -S                        
   
      2.修改main.js文件
      #import axios from 'axios'
      #import qs from 'qs'
      import axios from '@/api/http'             #vue项目对axios的全局配置      
      import VueAxios from 'vue-axios' 
      Vue.use(VueAxios,axios)

3.之后就可以直接在Vue组件文件的methods里使用了  
      this.axios.post(url,params).then(resp => {
      console.log(resp);
      }).catch(resp=>{});

5.axios提交方式
  1.GET提交
       axios.get('/user', {//注意数据是保存到json对象的params属性
        params: {
          ID: 12345
        }
      }).then(function (response) {
        console.log(response);
      }).catch(function (error) {
        console.log(error);
      });

2.POST提交
  axios.post('/user', {//注意数据是直接保存到json对象
        firstName: 'Fred',
        lastName: 'Flintstone'
      }).then(function (response) {
        console.log(response);
      }).catch(function (error) {
        console.log(error);
      });

3.vue项目对axios的全局配置
 路径src/api/http.js

/**
 * vue项目对axios的全局配置
 */
import axios from 'axios'
import qs from 'qs'
 
//引入action模块,并添加至axios的类属性urls上
import action from '@/api/action'
axios.urls = action
 
// axios默认配置
axios.defaults.timeout = 10000; // 超时时间
// axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
axios.defaults.baseURL = action.SERVER;
 
//整理数据
// 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
axios.defaults.transformRequest = function(data) {
    data = qs.stringify(data);
    return data;
};
 
 
// 请求拦截器
axios.interceptors.request.use(function(config) {
    return config;
}, function(error) {
    return Promise.reject(error);
});
 
// 响应拦截器
axios.interceptors.response.use(function(response) {
    return response;
}, function(error) {
    return Promise.reject(error);
});
 
// // 路由请求拦截
// // http request 拦截器
// axios.interceptors.request.use(
//     config => {
//         //config.data = JSON.stringify(config.data);  
//         //config.headers['Content-Type'] = 'application/json;charset=UTF-8';
//         //config.headers['Token'] = 'abcxyz';
//         //判断是否存在ticket,如果存在的话,则每个http header都加上ticket
//         // if (cookie.get("token")) {
//         //     //用户每次操作,都将cookie设置成2小时
//         //     cookie.set("token", cookie.get("token"), 1 / 12)
//         //     cookie.set("name", cookie.get("name"), 1 / 12)
//         //     config.headers.token = cookie.get("token");
//         //     config.headers.name = cookie.get("name");
//         // }
//         return config;
//     },
//     error => {
//         return Promise.reject(error.response);
//     });
 
// // 路由响应拦截
// // http response 拦截器
// axios.interceptors.response.use(
//     response => {
//         if (response.data.resultCode == "404") {
//             console.log("response.data.resultCode是404")
//             // 返回 错误代码-1 清除ticket信息并跳转到登录页面
//             //      cookie.del("ticket")
//             //      window.location.href='http://login.com'
//             return
//         } else {
//             return response;
//         }
//     },
//     error => {
//         return Promise.reject(error.response) // 返回接口返回的错误信息
//     });
 
 
 
export default axios;
api/action.js

/**
 * 对后台请求的地址的封装,URL格式如下:
 * 模块名_实体名_操作
 */
export default {
    'SERVER': 'http://localhost:8080/j2eeVue', //服务器
    'SYSTEM_USER_DOLOGIN': '/userAction.action', //登陆
    'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
        return this.SERVER + this[k];
    }
}
6.登录案例
<template>
  <div class="login-wrap">
    <el-form class="login-container">
      <h1>用户登录</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" style="width: 100%;" @click="login">登录</el-button>
      </el-form-item>
      <el-row style="text-align: center;">
        <el-link type="primary" @click="doRegister">注册账号</el-link>
        <el-link type="primary" @click="toLogin">忘记密码</el-link>
      </el-row>
    </el-form>
  </div>
</template>
<script>
  // import axios from 'axios'
  // import qs from 'qs'
export default {
  name: 'Login',
  data:function () {
    return {
      username:'',
      password:'',
    }
  },
  methods: {
    login:function(){
      let username=this.username;
      let password=this.password;
      //定义请求路径
      let url=this.axios.urls.SYSTEM_USER_DOLOGIN;//userAction.action
 
      //定义请求参数
      let params = {
        username:username,
        password:password,
        methodName:'userLogin'
      }
      console.log(params)
      // this.axios.post(url,params).then(resp=>{
      //   let data=resp.data;
      //   console.log(data);
      //   this.$message({
      //     message: data.msg,
      //     type : data.code==1?'success':'error'
      //   });
      // }).catch(err=>{
      //    console.log(err);
      // });
 
 
      this.axios.get(url,{params:params}).then(resp=>{
        let data=resp.data;
        console.log(data);
        this.$message({
          message: data.msg,
          type : data.code==1?'success':'error'
        });
        if(data.code==1)
              this.$router.push('/Main')
      }).catch(err=>{
         console.log(err);
      });
 
 
    },
    doRegister:function(){
      this.$router.push('/Register')
    },
    toLogin:function(){
      this.$router.push('/')
    }
  }
}
</script>
 
<style>
  .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>

【element-ui】相关推荐

  1. 【 Element UI 】—Element UI 的基本使用

    [ Element UI ]-Element UI 的基本使用 一.基于命令行的方式手动安装 npm 安装 npm i element-ui -S CDN 目前可以通过 unpkg.com/eleme ...

  2. npm创建Vue工程【element UI】

    npm创建Vue工程[element UI] 步骤 # 初始化一个名为 hello-vue 的Vue工程 vue init webpack hello-vue# 进入 hello-vue 工程 cd ...

  3. 【Element UI】日期选择器el-date-picker 默认选中当前日期==> 不可选当日之前的日期

    一个人能否合理表达自己的攻击性是健康与否的重要标准. 参考Element UI  Element - The world's most popular Vue UI framework 目录 1.默认 ...

  4. vue【element ui】el-date-picker 日期选择器控件 限制可选的开始时间和结束时间

    项目场景: 总结一下日期控件实现开始日期.结束日期的选择范围限制,以便更符合实际情况. 需求: 1.开始时间和结束时间都不能选当前日期之后的时间.(当前时间:2022年5月16日) 2.先选开始时间的 ...

  5. 【Vue+Element UI】关闭指定某一个页面的loading动画

    [Vue+Element UI]关闭指定某一个页面的loading动画 模板:vue-admin-template v4.4.0 问题描述:由于vue-admin默认配置了全局loading,所以页面 ...

  6. 【Android UI】图片 + 文字展示by SpannableStringBuilder

    起源 图片和文字混合展示,比如这么个需求,需要在每段文字的左边要有一个小圆点,(小圆点符号在android系统中并不支持). 先用TextView的setDrawableLeft, 嗯,达到要求,那么 ...

  7. 【Lyra UI】UI 玩法逻辑小结

    [Lyra UI]UI 玩法逻辑小结 UI 这块分两个部分:功能版逻辑 + 材质效果 本篇讨论逻辑,即怎么组织UI结构,代码怎么串联事件和逻辑 笔者之前并没有用UE开发过游戏,也算是从零开始,所以并不 ...

  8. 【Android UI】贝塞尔曲线 ⑦ ( 使用 德卡斯特里奥算法 公式计算的 方法绘制三阶贝塞尔曲线示例 )

    文章目录 一.使用 德卡斯特里奥算法 公式计算的 方法绘制三阶贝塞尔曲线 二.代码示例 贝塞尔曲线参考 : https://github.com/venshine/BezierMaker 一.使用 德 ...

  9. 【Element ui 的NavMenu二级菜单下拉icon修改】

    Element ui 的NavMenu二级菜单下拉icon修改 原来是这样的,下拉icon在右边 修改成icon在左边,并更改icon的形状 修改icon的css属性,覆盖原来的.需要注意的是取消打开 ...

  10. 【element ui --- DateTimePicker,有效时间不能晚于当前时间】

    如上图所示: 下面展示一些 内联代码片. // DateTimePicker 日期时间组件<el-form-item label="有效时间" prop="expi ...

最新文章

  1. cv2.findContours
  2. python和c++哪个好找工作-Scratch和Python与C++选哪个合适
  3. ros_openvino_toolkit环境搭建纪实
  4. 随机化算法-----模拟退火
  5. 耗时6年的DK博物科普巨著,全面提升孩子的认知高度
  6. ucGUI 架构介绍
  7. 白噪音和粉红噪音煲机_白噪音信号的概念及基本理论
  8. java回收内存_JAVA之内存回收
  9. JAVA和C#,武当和少林之争!
  10. C语言中188 10取模等于多少,C语言编程:任取x为十进制整数,编程将x转换成对应的八进制数后输出。...
  11. [算法模板]高斯消元
  12. c语言——约瑟夫环(数组)
  13. iso27001认证怎么申请?(iso27001认证基本条件和详细流程)
  14. GIS专业/GIS方向需要考那些证书
  15. charles(青花瓷)抓包配置mac ios版,详细好用
  16. 布料仿真先导2-带阻尼的单个小球单摆下的拉格朗日方程列些和matlab仿真
  17. mysql主从IP地址变更
  18. 风控决策引擎——决策流构建实战
  19. 比 ping 强大百倍的可视化工具!结果一目了然
  20. QIIME 2教程. 06沙漠土壤分析AtacamaSoil(2021.2)

热门文章

  1. sublime的自动保存设置
  2. 网上购车平台其实也可以这样上私户
  3. Online Learning and Pricing with Reusable Resources: Linear Bandits with Sub-Exponential Rewards: Li
  4. 保姆级高通AEC9调试指南(看完可解决80%AE相关问题)
  5. 【干货书】Python中的商业分析概念、技术和应用的数据挖掘
  6. python狗品种识别_使用python+keras来识别狗的品种
  7. Spark算子实战Java版,学到了
  8. 关闭Eslint中的规则 no-unused-vars
  9. 拼出爱心图案的c语言,抖音用猪头云朵和爱心微信表情拼成的表白图的口诀表...
  10. uniapp开发微信小程序弹窗自用封装