Vue项目中jsonp抓取数据实现方式
因为最近在做vue的项目,在前端做数据的时候遇到了数据抓取的难题,查了一些资料,自己也研究了一下,总体来说是搞出来了(基于黄奕老师的项目找出来的经验),废话不多说,直接上代码
----------------------------------------------------
----------------------------------------------------
----------------------------------------------------
先安装依赖:cnpm install --save jsonp
1. 然后创建一个jsonp.js
import originJSONP from 'jsonp' //引用jsonp
export default function jsonp(url,data,options){
//地址判断和调用处理地址函数
url +=(url.indexOf('?')<0?'?':'&')+param(data)
//返回一个Promise
return new Promise((resolve,reject)=>{
originJSONP(url,options,(err,data)=>{ //用原始的jsonp调用有三个参数
if(!err){
resolve(data)
}else{
reject(err)
}
})
})
}
2、创建一个函数处理地址
1 function param(data){
2
3 let url = '';
4
5 for(var k in data){
6
7 let value = data[k]!==undefined?data[k]:'';
8
9 url +=`&${k}=${encodeURIComponent(value)}`; //地址拼接参数
10
11 }
12 return url ? url.substring(1):''
13 }
2.自己创建个api文件夹,创建一个recomm.js,config 主要用途是处理请求地址url和头部的公共参数,引入刚刚的jsonp.js
代码如下:
1 import jsonp from '' // jsonp.js文件地址;
2
3 import {commonParams,options} from 'config.js 文件地址' //把congfig.js 对象导入进来
4
5 export function getRemented(){
6
7 const url = '这个是你想要挖掘的地址' ;
8
9 //例如我想要的地址是:https://c.y.qq.com/musichall/fcgi-bin/fcg_yqqhomepagerecommend.fcg
10
11 const data = Object.assign({},commonParams, //这些参数都是可以在network Header 下
12 query string parameters
13 platform:'h5',
14 uin:0,
15 needNewCode:1
16 })
17
18 return jsonp(url,data,options)
19 }
20
21
3. config.js //用途把公共的参数提取出来
代码如下:
1 export const commonParams = {
2 g_tk:5318,
3 inCharset: 'utf-8',
4 outCharset:'utf-8',
5 notice:0,
6 format:'jsonp'
7 }
8 export const options = {
9 param:'jsonpCallback'
10 }
11 export const ERR_OK = 0;
12
13 //在自己的模块中调用 既可以看到数据
14
15 <template>
16 <div id="app"></div>
17 </template>
18
19 <script type="text/ecmascript-6">
20
21 import{getRemented} from '../../api/recomm'
22
23 import {ERR_OK} from '../../api/config'
24
25 export default{
26 data(){
27 return{}
28 },
29 created(){
30 this._getData();
31 },
32 methods:{
33 _getData (){
34 getRemented ().then((res)=>{
35 if(res.code===ERR_OK){
36 console.log(res.data)
37 }
38 })
39 }
40 }
41 }
42
43 </script>
44
45 <style lang="scss">
46
47 #app {
48
49 font-family: 'Avenir', Helvetica, Arial, sans-serif;
50
51 -webkit-font-smoothing: antialiased;
52
53 -moz-osx-font-smoothing: grayscale;
54
55 text-align: center;
56
57 /*color: #2c3e50;*/
58
59 }
60
61 </style>
62
63
VUE解决axios跨域问题
![]()
Vue项目中jsonp抓取数据实现方式的更多相关文章
- windows环境下nutch2.x 在eclipse中实现抓取数据存进mysql详细步骤
nutch2.x 在eclipse中实现抓取数据存进mysql步骤 最近在研究nutch,花了几天时间,也遇到很多问题,最终结果还是成功了,在此记录,并给其他有兴趣的人提供参考,共同进步. 对nutc ...
- Vue项目中v-for无法渲染数据
在Vue项目中,我们想要实现下面的布局效果 后端返回的数据格式如下,可以看出产品列表五张图的数据位于同一个数组中 而我的html结构如下: 我希望直接渲染左边一张大图,然后右边的四张小图通过v-for ...
- vue项目中导出PDF的两种方式
参考大家导出的方式,基本上是如下两种: 1.使用 html2Canvas + jsPDF 导出PDF, 这种方式什么都好,就是下载的pdf太模糊了.对要求好的pdf这种方式真是不行啊! 2.调用浏览器 ...
- vue项目中引用echarts的几种方式
准备工作: 首先我们初始化一个vue项目,执行vue init webpack echart,接着我们进入初始化的项目下.安装echarts, npm install echarts -S //或 ...
- vue 项目中使用mock假数据实现前后端分离
也是查了很多的资料,整理出来.实现了前后端的分离,用到的技术vue-cli,webpack,node,json-server.首先全局安装json-server cnpm i json-server ...
- vue项目中返回之前页面数据不刷新的问题
利用vue做项目的时候会有让用户选择当前页面的某些数据,然后再跳到下一页,而下一页是根据上一页的数据来的,有时候选择了上一页的不同选项,下一页的数据可能还是之前的 这个就属于vue的数据获取问题 解决 ...
- php中CURL技术模拟登陆抓取数据实战,抓取某校教务处学生成绩。
这两天有基友要php中curl抓取教务处成绩的源码,用于微信公众平台的开发.下面笔者只好忍痛割爱了.php中CURL技术模拟登陆抓取数据实战,抓取沈阳工学院教务处学生成绩. 首先,教务处登录需要验证码 ...
- 在vue项目中, mock数据
1. 在根目录下创建 test 目录, 用来存放模拟的 json 数据, 在 test 目录下创建模拟的数据 data.json 文件 2.在build目录下的 dev-server.js的文件作如下 ...
- Python开源爬虫项目代码:抓取淘宝、京东、QQ、知网数据--转
数据来源:数据挖掘入门与实战 公众号: datadw scrapy_jingdong[9]- 京东爬虫.基于scrapy的京东网站爬虫,保存格式为csv.[9]: https://github.co ...
随机推荐
- 深入浅出mongoose
深入浅出mongoose mongoose是nodeJS提供连接 mongodb的一个库. 此外还有mongoskin, mongodb(mongodb官方出品). 本人,还是比较青睐mongoose ...
- 红透半边天的VR(虚拟现实)产业
目前在做一些与AR与VR相关的工作,特此把一些个人总结的普及性概念与各位朋友共享. 一: 什么是虚拟现实(VR)技术? 虚拟现实技术是一种可以创建和体验虚拟世界的计算机仿真系统它利用计算机生成一种模拟 ...
- [翻译] 对正在使用EF6x开发人员的一些话
Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...
- Flink从入门到放弃(入门篇1)-Flink是什么
戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...
- 进阶!基于CentOS7系统使用cobbler实现单台服务器批量自动化安装不同版本系统(week3_day5_part2)-技术流ken
前言 在上一篇博文<cobbler批量安装系统使用详解-技术流ken>中已经详细讲解了cobbler的使用以及安装,本篇博文将会使用单台cobbler实现自动化批量安装不同版本的操作系统. ...
- IOS多态在项目中的应用
今天我们讲述一个知识点(大家可能遗漏的) 多态是面试程序设计(OOP)一个重要特征,但在iOS中,可能比较少的人会留意这个特征,实际上在开发中我们可能已经不经意的使用了多态.比如说: 有一个table ...
- asp.net mvc 三层加EF 登录注册 增删改查
首先打开vs软件新建项目创建web中的mvc项目再右击解决方案创建类库项目分别创建DAL层和BLL层再把DAL层和BLL层的类重命名在mvc项目中的Models文件夹创建model类在DAL创建ADO ...
- 关于C#chart图表实现多条折线动态绑定数据的问题
之前就已经实现了多条折线绑定数据并显示,但不是动态绑定,而是每一条数据都要进行一次绑定,个人觉得在解决实际问题时,这样的解决方法过于笨重且缺乏扩展性,这次主要是对代码进行优化,实现写一遍代码,无论数据 ...
- Jmeter、Java当double显示的数字过长时取消科学计数法显示
今日,由于项目需要,使用Jmeter发送查询账户并不保存余额,经过交易后,进行运算后再次比对余额. 实施过程中获取了余额字段并赋值给一个double变量.变量进行运算后再与交易后的账户余额进行比对.这 ...
- Java:全局变量(成员变量)与局部变量
分类细则: 变量按作用范围划分分为全局变量(成员变量)和局部变量 成员变量按调用方式划分分为实例属性与类属性 (有关实例属性与类属性的介绍见另一博文https://blog.csdn.net/Drag ...