axios和vuex
0.babel
将es6代码转换成各个浏览器都能识别的代码
一.axios
1.官方网站
https://www.kancloud.cn/yunye/axios/234845
2.引用:
(1)cdn
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
(2)下载到当前项目***
npm install axios
3.用法
(1)get请求
// 为给定 ID 的 user 创建请求
axios.get('/user?ID=12345')
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
}); // 可选地,上面的请求可以这样做
axios.get('/user', {
params: {
ID: 12345
}
})
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
(2)post请求
axios.post('/user', {
firstName: 'Fred',
lastName: 'Flintstone' })
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
4.使用实例
在main.js中,将Axios挂载到 Vue原型上,每一个子组件都能够使用
import Axios from 'axios' Vue.prototype.$https = Axios Axios.defaults.baseURL = 'https://www.luffycity.com/api/v1/';
二.vuex
作用:组件之间的传值,任何一个组件都能共享state中的数据
下载vuex到该组件:npm i vuex -S
1.vuex商店的创建
在main.js中
import Vue from 'vue'
import App from './App'
import router from './router/index' //1.引入
import Vuex from "vuex"
//2.组件使用要use
Vue.use(Vuex)
//3.创建一个store实例
const store=new Vuex.Store({
state:{},
mutations:{},
actions:{},
}) new Vue({
el: '#app',
router,
//4.挂载store实例
store,
components: { App},
template: '<div><App></App></div>'
})
2.值的使用
<template>
<div class="">
//2.使用
<h3>我是主页,我是父组件中的{{ num }}</h3> </div>
</template> <script>
export default {
name: 'Home',
data () {
return { }
},
//监听
computed:{
//1.定义方法,调用store,返回store中的值
num:function(){
return this.$store.state.num
}
}
}
</script> <style > </style>
3.值的同步修改
在main.js
import Vue from 'vue'
import App from './App'
import router from './router/index' // Vue.config.productionTip = false import Vuex from "vuex"
Vue.use(Vuex)
const store=new Vuex.Store({
state:{num:111},
mutations:{
//1.定义如何修改
setNum(state,val){
state.num+=val
}
},
actions:{},
}); new Vue({
el: '#app',
router,
//4.挂载store实例
store,
components: { App},
template: '<div><App></App></div>'
});
在Course.vue中
<template>
<div>我是课程
<button @click="setnum">+1按钮</button>
我是父组件中的{{ num }}
</div>
</template>
<script>
export default{
methods:{
//2.确定修改
setnum(){
this.$store.commit("setNum",1)
}
},
computed:{
num:function(){
return this.$store.state.num
}
}
}
</script>
<style></style>
4.值的异步修改
在main.js中
import Vue from 'vue'
import App from './App'
import router from './router/index' import Vuex from "vuex"
Vue.use(Vuex)
const store=new Vuex.Store({
state:{num:111},
mutations:{
setMutaNum(state,val){
state.num+=val
},
setMutaAsync:function(state,val){
state.num+=val
}
},
actions:{
setActionNum(context,val){
context.commit('setMutaNum',val)
},
setActionAsync(context,val){
setTimeout(()=>{
context.commit('setMutaAsync',val)
})
}
},
}); new Vue({
el: '#app',
router,
//4.挂载store实例
store,
components: { App},
template: '<div><App></App></div>'
});
在course.vue中
<template>
<div>我是课程
<button @click="setnum">同步+1按钮</button>
<button @click="setAsynanum">异步 +5按钮</button>
我是父组件中的{{ num }}
</div>
</template>
<script>
export default{
methods:{
setnum(){
this.$store.dispatch("setActionNum",1)
},
setAsynanum(){
this.$store.dispatch("setActionAsync",5)
}
},
computed:{
num:function(){
return this.$store.state.num
}
}
}
</script>
<style></style>
流程如下

axios和vuex的更多相关文章
- day 84 Vue学习六之axios、vuex、脚手架中组件传值
Vue学习六之axios.vuex.脚手架中组件传值 本节目录 一 axios的使用 二 vuex的使用 三 组件传值 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 axios的 ...
- day 87 Vue学习六之axios、vuex、脚手架中组件传值
本节目录 一 axios的使用 二 vuex的使用 三 组件传值 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 axios的使用 Axios 是一个基于 promise 的 HT ...
- Vue(5)- axios、vuex
一.内容回顾 1.webpack(前端中工作,项目上线之前对整个前端项目优化) - entry:整个项目的程序入口(main.js或index.js): - output:输出的出口: - loade ...
- Vue2基于Axios Ajax Vuex的Loading组件
1. 定义根state:ajaxIsLoading2. 在Axios拦截器中commit不同的状态实现状态切换3. 组件中通过getter获取ajaxIsLoading状态 Axios 拦截器配置 i ...
- Vue 5 -- axios、vuex
一.内容回顾 1.webpack(前端中工作,项目上线之前对整个前端项目优化) - entry:整个项目的程序入口(main.js或index.js): - output:输出的出口: - loade ...
- 【实战】Vue全家桶(vue + axios + vue-router + vuex)搭建移动端H5项目
使用Vue全家桶开发移动端页面. 本博文默认已安装node.js. github链接 一.准备工作 安装vue npm install vue 安装脚手架vue-cli npm install -g ...
- [前端] VUE基础 (9) (element-ui、axios、Vuex)
一.element-ui的使用 官方网页:https://element.eleme.cn/#/zh-CN 1.安装element-ui (venv) D:\pycharm_workspace\vue ...
- Vuex与axios介绍
Vuex集中式状态管理里架构 axios (Ajax) Vuex集中式状态管理架构 -简单介绍: vuex是一个专门为Vue.js设计的集中式状态管理架构. 我们把它理解为在data中需要共享给其他组 ...
- vue-x和axios的学习
axios的使用 使用原因:因为vue本身就带有处理dom的功能,不希望再有其他操作dom的插件,所以用axios代替了jquery 功能:发送xhr请求 下载: $ npm install axio ...
随机推荐
- C#高效率复制对象
高效率复制对象 1.需求 在代码中经常会遇到需要把对象复制一遍,或者把属性名相同的值复制一遍. 比如: public class Student { public int Id { get; set; ...
- WPF 触摸到事件
原文:WPF 触摸到事件 本文从代码底层告诉大家,在触摸屏幕之后是如何拿到触摸点并且转换为事件 在 WPF 界面框架核心就是交互和渲染,触摸是交互的一部分.在 WPF 是需要使用多个线程来做触摸和渲染 ...
- express笔记
1.req.query: 获取get请求的查询字符串对象 2.req.body: 获取post请求的查询字符串对象,要使用该方法需要先使用body-parser中间件,app.use(bodyPars ...
- 一款有意思的 Qt 飞行仪表控件
最近在网上偶然发现一款Qt飞行仪表板控件,真的很酷哦! 是一款开源软件, 直接编译运行: 美工还是不错的! 控件操作非常简单: void MainWindow::timerEvent( QTimer ...
- 设置vista和win7进入Debug模式
转载请标明是引用于 http://blog.csdn.net/chenyujing1234 欢迎大家拍砖 设置vista和win7进入Debug模式: 1. bcdedit /copy {curre ...
- 设置npm淘宝镜像
npm config set registry https://registry.npm.taobao.org
- 0-1分布(伯努利分布)、n 重伯努利分布(二项分布)
1. 0-1 分布(伯努利分布) 0-1分布又名两点分布,或叫伯努利分布. P{X=k}=pk(1−p)1−k 其中 k=0,1. 伯努利分布未必一定是 0-1 分布,也可能是 a-b 分布,只需满足 ...
- Qt浅谈之十八:GraphicsView框架事件处理(有源码下载)
一.简介 GraphicsView支持事件传播体系结构,可以使图元在场景scene中得到提高了已被的精确交互能力.图形视图框架中的事件都是首先由视图进行接收,然后传递给场景,再由场景给相应的图形项. ...
- Android笔记--自定义控件仿遥控器的圆形上下左右OK圆盘按钮
原文:Android笔记--自定义控件仿遥控器的圆形上下左右OK圆盘按钮 上面就是几张预览图!代码在最底下 主要就两个步骤,画图.监听点击 1.整个控件基本上是一步步画出来的,重写onDraw方法开始 ...
- 安装mysql5.7.17
参见 网易云课堂的视频教程 :mysql视频教程