Vue项目中使用jsonp抓取跨域数据的方法
网络编程 2021-07-04 15:02www.168986.cn编程入门
这篇文章主要介绍了Vue项目中使用jsonp抓取跨域数据的方法,本文通过实例代码讲解的非常详细,需要的朋友可以参考下
- 下载jsonp npm install jsonp
- 在js文件夹下新增一个jsonp.js,来封装一个jsonp()
如何封装一个jsonp()
在下载的jsopn中,jsonp(url,options,callback)这个是原生jsonp方法中的参数;
引入下载的jsonp
import originJsonp from 'jsonp';
导出自己定义的jsonp函数
//这个jsonp函数是我们自己定义的,与上面的originJsonp不是同一个,originJsonp是一个可以直接引用的方法;她最
终返回一个Promise对象
export default function jsonp(url, data, option){ return new Promise((resolve,reject)=>{ //调用originJsonp()来抓取数据 originJsonp(url,option,(err,data)=>{ //callback是抓取数据结果 if(!err){ resolve(data) }ese{ reject(err) } }) }) }
在抓取的数据URL中常常会有参数传入,这些参数是对象格式,我们传入到originJsonp方法中的参数是拼接到url后面的,所以不能是对象的格式,这时就需要将对象格式的参数拼接到url后面组成新的URL
类似这样的一个url( ... ;
这里参数data{
ie:utf-8, rsv_bp:1 } export function param(data){ let urlData=''; for(let key in data){ let value = data[k] !== undefined ? data[k] : '' ;//用来判断data是不是空 //将data拼接起来 if(vaule){ urlData += ·'&'${k}=${encodeURIComponent(value)}·;//encodeURIComponent将进行网址的拼接 (encodeURIComponent()是将字符串转换成url地址 } } return urlData ? urlData.substring(1):''; //url.substring(1)的原因是,有可能这个url后面接的参数用的是'?‘;我们只需要将参数用‘&'连接起来,不用管URL后面紧接的那个符号【是?还是&】 }
将函数param引用到函数jsonp中
export default function jsonp(url, data, option) { return new Promise((resolve,reject)=>{ //调用跨域请求函数 //对URL进行拼接,首页需要判断URL后面是否有“?”,如果有这需要给param(data)添加“&”,不然需要给param(data)添加“?” url = url.indexOf('?')<0 ? '?':'&' + param(data); originJsonp(url,option,(err,data)=>{ //这里的url就是完整的请求地址,需要包括参数 if(!err){ resolve(data) //请求成功 }else{ reject(err) //失败 } }) }) }
以上所述是长沙网络推广给大家介绍的Vue项目中使用jsonp抓取跨域数据的方法,希望对大家有所帮助!
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南