新建项目
vue init webpack axios_resource
然后具体设置如下
data:image/s3,"s3://crabby-images/db61a/db61a31f83283b8ad41b02d7d2baaa8184eb8e3b" alt=""
项目名称,项目描述,作者,Runtime + Compiler 回车即可
注意这里要安装vue-router和ESLint
然后 Setup unit tests with Karma + Mocha?
和 Setup e2e tests with Nightwatch?
都选择n即可
1.2 安装项目依赖
cnpm install
data:image/s3,"s3://crabby-images/30fd8/30fd8d604c6b0de696aff5daf51e5765b18d8f65" alt=""
1.3 安装 axios
模块
cnpm install axios --save
1.4 安装 resource
模块
cnpm install vue-resource --save
1.5 运行项目
cnpm run dev
效果图如下
data:image/s3,"s3://crabby-images/34037/34037721271ae5c1f0073e4efdebe5f1cb460ae1" alt=""
1.6 修改页面内容
我们先修改一下页面内容 src\components\Hello.vue
<template> <div class="hello"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> </div> </template> <script> export default { name: 'hello', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊' } } } </script>
效果图如下
data:image/s3,"s3://crabby-images/6f54b/6f54b51b1bb2c4ff0d8afbf5cb003ea8a22c9af5" alt=""
2. 使用axios
2.1 我们先修改一下页面,让页面加载一些动态内容
模板修改如下
<template> <div class="hello"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> <ul v-for="music in musics"> <li> {{ music.name }} </li> </ul> </div> </template>
js部分修改如下
<script> export default { name: 'hello', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊', musics: [] } }, mounted: function () { axios.get('http://music.163.com/api/playlist/detail?id=19723756') .then(function (res) { console.log(res) }, function (error) { console.log(error) }) } } </script>
然后保存
发现页面有一个报错 http://eslint.org/docs/rules/no-undef 'axios' is not defined
data:image/s3,"s3://crabby-images/2ca8a/2ca8a3afbab241deb2efc2b04ddf9c443485b55f" alt=""
axios没有定义,是因为我们没有导入axios模块的原因
我们在js部分顶部导入一下axios模块
import axios from 'axios'
加载axios模块之后错误提示消失了。 打开调试页面console界面 发现有一个报错
No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://localhost:8080' is therefore not allowed access.
data:image/s3,"s3://crabby-images/2c70e/2c70ed5cef8680a985e4d53f2693719481939c03" alt=""
这里的 not allowed access
就是提示我们浏览器不支持跨域请求,搜索了很多资料,网易云不支持跨域请求的(网易云的服务器在返回你的请求中没有Access-Control-Allow-Origin这个head字段)。
那怎么办呢? 那我们只能使用代理了。
下面将介绍3种代理方式:1,远程代理 2,php代理 3,node代理
3 代理
3.1 远程代理
就是利用别人写好的代理接口,代理发送你的请求,这样就不会跨域了。
首先我们定义一个常量 API_PROXY
const API_PROXY = 'https://bird.ioliu.cn/v1/?url='
然后在 axios
请求里面拼接一下字符串
axios.get(API_PROXY + 'http://music.163.com/api/playlist/detail?id=19723756')
js 完整代码如下
<script> const API_PROXY = 'https://bird.ioliu.cn/v1/?url=' import axios from 'axios' export default { name: 'hello', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊', musics: [] } }, mounted: function () { axios.get(API_PROXY + 'http://music.163.com/api/playlist/detail?id=19723756') .then(function (res) { console.log(res) }, function (error) { console.log(error) }) } } </script>
打开浏览器 console
界面
Object {data: Object, status: 200, statusText: "OK", headers: Object, config: Object…}config: Objectdata: Objectheaders: Objectrequest: XMLHttpRequeststatus: 200statusText: "OK"__proto__: Object
请求成功
赋值给 musics
this.musics = res.data.result.tracks
发现页面有个报错
Uncaught (in promise) TypeError: Cannot set property 'musics' of undefined
musics没有定义 因为这里,this的指向不是当前的vue实例 那我们在使用 axios
之前重新,定义一下this
var _this = this
在 axios
使用 _this
就好了
mounted部分代码
mounted: function () { var _this = this axios.get(API_PROXY + 'http://music.163.com/api/playlist/detail?id=19723756') .then(function (res) { _this.musics = res.data.result.tracks console.log(_this.musics) }, function (error) { console.log(error) }) }
再打开控制台,发现没有报错,请求的数据也是我们想要的
data:image/s3,"s3://crabby-images/4e3fe/4e3fe197114a879e63ab7b902f142d5c14e710f8" alt=""
再次修改一下模板
我们再增加图片数据
修改好的模板如下
<template> <div class="hello"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> <ul v-for="music in musics"> <li> {{ music.name }} </li><br> <li> <img :src="music.album.picUrl" > </li> </ul> </div> </template>
完整代码如下
<template> <div class="hello"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> <ul v-for="music in musics"> <li> {{ music.name }} </li><br> <li> <img :src="music.album.picUrl" > </li> </ul> </div> </template> <script> const API_PROXY = 'https://bird.ioliu.cn/v1/?url=' import axios from 'axios' export default { name: 'hello', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊', musics: [] } }, mounted: function () { var _this = this axios.get(API_PROXY + 'http://music.163.com/api/playlist/detail?id=19723756') .then(function (res) { _this.musics = res.data.result.tracks console.log(_this.musics) }, function (error) { console.log(error) }) } } </script>
最后效果图如下
data:image/s3,"s3://crabby-images/245ff/245ff2e9322fb487840f8ce210a5815dfb6ec82f" alt=""
3.2 php用curl代理
这里演示vue-resource的写法 + php curl 完成代理请求
前面我们安装了 vue-resource
模块,我们要在 main.js
加载一下 vue-resource
模块
加载
import VueResource from 'vue-resource'
使用
Vue.use(VueResource)
为了避免和之前页面混淆,我们重新新增一个curl页面,路由同样新增加一条'/curl'的路由
index.js 完整代码如下
import Vue from 'vue' import Router from 'vue-router' import Hello from '@/components/Hello' import Curl from '@/components/Curl' import VueResource from 'vue-resource' Vue.use(Router) Vue.use(VueResource) export default new Router({ routes: [ { path: '/', name: 'Hello', component: Hello }, { path: '/curl', name: 'Curl', component: Curl } ] })
其实 vue-resource
get方法基本上和 axios
很像,基本上没有太多变动
mounted: function () { this.$http.get('http://localhost/curl.php', {}, { headers: { }, emulateJSON: true }).then(function (res) { this.musics = res.data.result.tracks console.log(this.musics) }, function (error) { console.log(error) }) }
headers get方法里面不用填写参数,如果是post方式发送请求 则要设置 Access-Control-Allow-Origin: *
完整代码如下 src\components\Curl.vue
<template> <div class="curl"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> <ul v-for="music in musics"> <li> {{ music.name }} </li><br> <li> <img :src="music.album.picUrl" > </li> </ul> </div> </template> <script> export default { name: 'curl', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊', musics: [] } }, mounted: function () { this.$http.get('http://localhost/curl.php', {}, { headers: { }, emulateJSON: true }).then(function (res) { this.musics = res.data.result.tracks console.log(this.musics) }, function (error) { console.log(error) }) } } </script>
当然了,最重要的是curl.php这个部分代码怎么写了 curl.php 完整代码
<?php // header('Content-type:text/html;Charset=utf-8'); header('Content-Type:text/json;charset=utf-8');//设置返回文件的类型 header('Access-Control-Allow-Origin: *');//设置允许所有跨域 $id = '19723756'; //id $va_url = 'http://music.163.com/api/playlist/detail?'; //验证的 url 链接地址 $post_fields = "id={$id}"; //post提交信息串 $curl = curl_init(); //初始化一个cURL会话,必有 //curl_setopt()函数用于设置 curl 的参数,其功能非常强大,具体看手册 curl_setopt($curl, CURLOPT_URL, $va_url); //设置验证登陆的 url 链接 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //设置结果保存在变量中,还是输出,默认为0(输出) curl_setopt($curl, CURLOPT_POST, 1); //模拟post提交 curl_setopt($curl, CURLOPT_POSTFIELDS, $post_fields); //设置post串 //避免https请求报错 Curl error: SSL certificate problem: unable to get local issuer certificate curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); $data = curl_exec($curl); //执行此cURL会话,必有 // echo "<pre>"; // print_r(json_decode($data)); echo $data; //检查是否有错误 if(curl_errno($curl)) { exit('Curl error: ' . curl_error($curl)); } curl_close($curl); //关闭会话
curl请求的话就解释了,大家可以去看手册 最重要的是设置头文件允许跨域
header('Access-Control-Allow-Origin: *');
如果没有设置这个的话,代理也是没有意思的,不然前端还是会提示跨域
当然啦,你要把curl.php这个文件丢在你apache或者nginx根目录,同时apache或者nginx服务器也别忘记启用了哦。
data:image/s3,"s3://crabby-images/13cd6/13cd68f036003d88dd6ba2c7314b1ccc3dbb5663" alt=""
3.3 nodejs代理
同样的我们新建一个 Node.vue
的模板和 /node
的路由
{ path: '/node', name: 'Node', component: Node }
index.js 完整代码
import Vue from 'vue' import Router from 'vue-router' import Hello from '@/components/Hello' import Curl from '@/components/Curl' import Node from '@/components/Node' import VueResource from 'vue-resource' Vue.use(Router) Vue.use(VueResource) export default new Router({ routes: [ { path: '/', name: 'Hello', component: Hello }, { path: '/curl', name: 'Curl', component: Curl }, { path: '/node', name: 'Node', component: Node } ] })
设置代理
打开config/index.js 修改 proxyTable: {}
部分 修改为
proxyTable: { '/api': { target: 'http://music.163.com/api', changeOrigin: true, pathRewrite: { '^/api': '' } } }
第一行的 '/api'
指的是虚拟路径 target指的是目标地址,也就是实际api的地址 pathRewrite规则重写
然后在代码页面修改一下请求地址
mounted: function () { this.$http.get('/api/playlist/detail?id=19723756', {}, { headers: { }, emulateJSON: true }).then(function (res) { this.musics = res.data.result.tracks console.log(this.musics) }, function (error) { console.log(error) }) }
/api/playlist/detail?id=19723756
上面的这个地址其实就等于 http://localhost:8080/api
+ /playlist/detail?id=19723756
注意这里一定要重启一下node,因为你修改了node的配置一定要重启才能生效
在命令符窗口 ctrl + c
然后重新执行 cnpm run dev
这时候,命令窗口会提示
[HPM] Proxy created: /api -> http://music.163.com/api [HPM] Proxy rewrite rule created: "^/api" ~> "" > Starting dev server...
说明代理成功
data:image/s3,"s3://crabby-images/56121/5612101d1542dc4e52e970ebfbafd7147348d761" alt=""
然后访问http://localhost:8080/#/node
data:image/s3,"s3://crabby-images/20d59/20d5962235c2bbd98e59bbecd7a8abd439ca77d3" alt=""
就能看到效果了 完整代码 src\components\Node.vue
<template> <div class="curl"> <h1>{{ msg }}</h1> <h2>{{ author }}</h2> <ul v-for="music in musics"> <li> {{ music.name }} </li><br> <li> <img :src="music.album.picUrl" > </li> </ul> </div> </template>
<script> export default { name: 'curl', data () { return { msg: 'vue调用网易云接口', author: '泥猴啊', musics: [] } }, mounted: function () { this.$http.get('/api/playlist/detail?id=19723756', {}, { headers: { }, emulateJSON: true }).then(function (res) { this.musics = res.data.result.tracks console.log(this.musics) }, function (error) { console.log(error) }) } } </script>
github地址 github.com/pandoraxm/v…
注:本文内容来自互联网,旨在为开发者提供分享、交流的平台。如有涉及文章版权等事宜,请你联系站长进行处理。