未加星标

webpack+vuex+axios 跨域请求数据的示例代码

字体大小 | |
[前端(javascript) 所属分类 前端(javascript) | 发布者 店小二05 | 时间 | 作者 红领巾 ] 0人收藏点击收藏

本文介绍了webpack+vuex+axios 跨域请求数据的示例代码,分享给大家,具体如下:

使用vue-li 构建 webpack项目,修改bulid/config/index.js文件

dev: {
env: require('./dev.env'),
port: process.env.PORT || 8080,
autoOpenBrowser: true,
assetsSubDirectory: 'static',
assetsPublicPath: '/',
proxyTable: {
'/v2': {
target: 'http://api.douban.com',
changeOrigin: true,
pathRewrite: {
'^/v2': '/v2'
}
}
},
}
在action.js 中想跨域请求

设置action.js:

import axios from 'axios'
export const GET_IN_THEATERS = ({
dispatch,
state,
commit
}) => {
axios({
url: '/v2/movie/in_theaters'
}).then(res => {
commit('in_theaters', res.data)
})
}

组件内使用:

<template>
<div class="movie-page">
<ul class="clearfix">
<movies-item v-for="(item,index) in movie_list" :key="index" :movie="item"></movies-item>
</ul>
</div>
</template>
<script>
import {mapState, mapActions, mapGetters} from 'vuex';
import MoviesItem from "./movie-item";
export default {
data () {
return {

}
},
components: {
MoviesItem
},
computed: {
...mapState({
movie_list: state => {
return state.in_theaters.subjects
}
})
},
methods: {

},
created () {
this.$store.dispatch('GET_IN_THEATERS')
},
mounted () {
}
}
</script>
<style lang="scss">
@import "./../../assets/reset.scss";
@import "./../../assets/main.scss";
.movie-page{
padding: 0 rem(40);
}
</style>
在组件内想跨域

在main.js设置:

import axios from 'axios'
// 将 axios 改写为 Vue 的原型属性,使在其它的组件中可以使用 axios
Vue.prototype.$axios = axios

在组件内设置:

<template>
<div class="movie-page">
<ul class="clearfix">
<movies-item v-for="(item,index) in movie_list" :key="index" :movie="item"></movies-item>

</ul>
</div>
</template>
<script>
import MoviesItem from "./movie-item";
export default {
data () {
return {
movie_list: []
}
},
components: {
MoviesItem
},
computed: {

},
methods: {
},
created () {

},
mounted () {
this.$axios.get('/v2/movie/in_theaters').then(res => {
this.movie_list = res.data.subjects
}, res => {
console.infor('error')
})
}
}
</script>
<style lang="scss">
@import "./../../assets/reset.scss";
@import "./../../assets/main.scss";
.movie-page{
padding: 0 rem(40);
}
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。


您可能感兴趣的文章:vue-cli webpack 开发环境跨域详解

本文前端(javascript)相关术语:javascript是什么意思 javascript下载 javascript权威指南 javascript基础教程 javascript 正则表达式 javascript设计模式 javascript高级程序设计 精通javascript javascript教程

主题: 数据
tags: gt,lt,movie,axios,import,scss,v2,跨域,list,index,res,theaters
分页:12
转载请注明
本文标题:webpack+vuex+axios 跨域请求数据的示例代码
本站链接:http://www.codesec.net/view/573650.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 前端(javascript) | 评论(0) | 阅读(36)