vue使用jsonp抓取qq音乐数据的方法
时间:2019-04-20
本文章向大家介绍vue使用jsonp抓取qq音乐数据的方法,主要包括vue使用jsonp抓取qq音乐数据的方法使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1、安装jsonp
npm install jsonp
2、创建jsonp.js文件,内容如下:
import originJSONP from 'jsonp' /** * 封装jsonp * @param {*} url 原始的jsonp第一个参数是url,第二个参数是option,这里为了比较好写参数做了下封装 * @param {obj} data 参数 * @param {*} option jsonp的option */ export default function jsonp (url, data, option) { // 如果url没有?就加一个?拼接 url += (url.indexOf('?') < 0 ? '?' : '&') + param(data) return new Promise((resolve, reject) => { // 原始jsonp的三个参数,url、option、回调函数 originJSONP(url, option, (err, data) => { // 类似node的设计,如果err是null,表示成功,data是后端返回的数据 if (!err) { resolve(data) } else { reject(err) } }) }) } export function param (data) { let url = '' for (var k in data) { let value = data[k] !== undefined ? data[k] : '' url += '&' + k + '=' + encodeURIComponent(value) } return url ? url.substring(1) : '' }
3、创建confiig.js文件,内容如下:
// 用于存放公共数据 export const commonParams = { g_tk: 5381, format: 'json', inCharset: 'utf - 8', outCharset: 'utf - 8', notice: 0 } export const options = { param: 'jsonpCallback' } export const ERR_OK = 0
3、创建recommend.js文件,内容如下:
import jsonp from './jsonp' import { commonParams, options } from './config' export function getRecommend () { const url = 'https://c.y.qq.com/musichall/fcgi-bin/fcg_yqqhomepagerecommend.fcg' const data = Object.assign({}, commonParams, { platform: 'h5', uin: 0, needNewCode: 1 }) // 这里返回一个promise对象 return jsonp(url, data, options) }
4、在组件中使用,如musicHall.vue中
<script> import {getRecommend} from '../api/recommend.js' import {ERR_OK} from '../api/config.js' export default { mounted () { //在created中也可 this._getRecommend() }, methods: { _getRecommend () { getRecommend().then((res) => { if (res.code === ERR_OK) { console.log(res.data.slider) } }) } } } </script>
5、总结
- Object.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target)
- Object.assign(target, source1, source2)
- encodeURIComponent(URIstring)函数可把字符串作为 URI 组件进行编码。 URIstring 必需。一个字符串,含有 URI 组件或其他要编码的文本。
- substring()方法用于提取字符串中介于两个指定下标之间的字符。
- stringObject.substring(start,stop)包括 start 处的字符,但不包括 stop 处的字符。不接受负的参数。
总结
以上所述是小编给大家介绍的vue使用jsonp抓取qq音乐数据的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Python简单实现自动删除目录下空文件夹的方法
- 基于jstree使用JSON数据组装成树
- Android Parcelable接口使用方法详解
- 基于jstree使用AJAX请求获取数据形成树
- 移动端Ionic App 资讯上下循环滚动的实现代码(跑马灯效果)
- Java NumberFormat 类的详解及实例
- Java语言十大基础特性分析
- jsTree事件和交互以及插件plugins详解
- View.post() 不靠谱的地方你知道多少
- java 工厂模式的讲解及优缺点的介绍
- java 泛型的详解及实例
- 简单学习Python多进程Multiprocessing
- java 出现NullPointerException的原因及解决办法
- js禁止表单重复提交
- C#实现文件上传及文件下载功能实例代码