因为最近在做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抓取数据实现方式的更多相关文章

  1. windows环境下nutch2.x 在eclipse中实现抓取数据存进mysql详细步骤

    nutch2.x 在eclipse中实现抓取数据存进mysql步骤 最近在研究nutch,花了几天时间,也遇到很多问题,最终结果还是成功了,在此记录,并给其他有兴趣的人提供参考,共同进步. 对nutc ...

  2. Vue项目中v-for无法渲染数据

    在Vue项目中,我们想要实现下面的布局效果 后端返回的数据格式如下,可以看出产品列表五张图的数据位于同一个数组中 而我的html结构如下: 我希望直接渲染左边一张大图,然后右边的四张小图通过v-for ...

  3. vue项目中导出PDF的两种方式

    参考大家导出的方式,基本上是如下两种: 1.使用 html2Canvas + jsPDF 导出PDF, 这种方式什么都好,就是下载的pdf太模糊了.对要求好的pdf这种方式真是不行啊! 2.调用浏览器 ...

  4. vue项目中引用echarts的几种方式

    准备工作: 首先我们初始化一个vue项目,执行vue init webpack echart,接着我们进入初始化的项目下.安装echarts, npm install echarts -S //或   ...

  5. vue 项目中使用mock假数据实现前后端分离

    也是查了很多的资料,整理出来.实现了前后端的分离,用到的技术vue-cli,webpack,node,json-server.首先全局安装json-server cnpm i json-server ...

  6. vue项目中返回之前页面数据不刷新的问题

    利用vue做项目的时候会有让用户选择当前页面的某些数据,然后再跳到下一页,而下一页是根据上一页的数据来的,有时候选择了上一页的不同选项,下一页的数据可能还是之前的 这个就属于vue的数据获取问题 解决 ...

  7. php中CURL技术模拟登陆抓取数据实战,抓取某校教务处学生成绩。

    这两天有基友要php中curl抓取教务处成绩的源码,用于微信公众平台的开发.下面笔者只好忍痛割爱了.php中CURL技术模拟登陆抓取数据实战,抓取沈阳工学院教务处学生成绩. 首先,教务处登录需要验证码 ...

  8. 在vue项目中, mock数据

    1. 在根目录下创建 test 目录, 用来存放模拟的 json 数据, 在 test 目录下创建模拟的数据 data.json 文件 2.在build目录下的 dev-server.js的文件作如下 ...

  9. Python开源爬虫项目代码:抓取淘宝、京东、QQ、知网数据--转

    数据来源:数据挖掘入门与实战  公众号: datadw scrapy_jingdong[9]- 京东爬虫.基于scrapy的京东网站爬虫,保存格式为csv.[9]: https://github.co ...

随机推荐

  1. 高效并发unsafe-星耀

    定义 Unsafe类是在sun.misc包下,不属于Java标准.但是很多Java的基础类库,包括一些被广泛使用的高性能开发库都是基于Unsafe类开发的,比如Netty.Cassandra.Hado ...

  2. vue里如何灵活的绑定class以及内联style

    在我们平常的前端开发中少不了对DOM的操作,以及样式的动态控制,那我们在使用vue的时候该如何灵活的绑定class呢 1.最简单一个class绑定 v-bind:class设置一个对象,可以动态地切换 ...

  3. .net core 使用IIS作为宿主Web服务器,部署常见问题

    ASP.NET Core 使用IIS作为Web服务器,部署在IIS上 所做的步骤部署完毕后,启动网站 出现 An error occurred while starting the applicati ...

  4. 在React中使用Typescript的实践问题总结

    1.布尔值的大小写问题: 声明变量类型的时候,使用小写boolean 2. 对于从父组件传递过来的函数,子组件在模版中调用时,如果采用原来的写法,会报错: 改变写法后是如下这样,如果有参数和函数返回值 ...

  5. C#连接基于Java开发IM——Openfire

    Openfire简介    Openfire 是开源的.基于可拓展通讯和表示协议(XMPP).采用Java编程语言开发的实时协作服务器.Openfire的效率很高,单台服务器可支持上万并发用户.    ...

  6. 数据结构——Java实现链栈

    一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 链栈是指采用链式存储结构实现的 ...

  7. Spring Tool Suite4(sts)复制粘贴卡顿(ctrl+v, ctrl+c)、按住ctrl也很卡

    最近在看<Spring in Action, Fifth Edition>,下载了Spring Tool Suite4,在使用的过程中发现了一些问题: 只要在复制粘贴(ctrl+c, ct ...

  8. Java建造(Builder)模式

    一.什么是建造模式: 建造模式可以将一个产品的内部表象与产品的生成过程分割开来,从而使一个建造过程生成具有不同内部表象的产品.客户端不需要知道产品内部的结构和生产过程. 二.建造模式的结构: Buil ...

  9. 覆盖ng-zorro样式(非style.scss)

    之前发现在模板的样式表里写样式不起作用,然后想起vue里有个/deep/,angular会不会也有一个,果然,发现了一个::ng-deep可以在模板的样式表里覆盖ng-zorro的样式.记录一下(●' ...

  10. 复活广州.net俱乐部

    上个月张队长在深圳搞了一场活动,我们广州这边的.net粉丝也去了几个,我刚好有辆破车,于是我们一车会合后出发去深圳参加活动了,和大家在车上的交流使我感触良多.只说几点和本文相关的: .net在中国的生 ...