您的位置:首页 > 产品设计 > UI/UE

四十、vue中封装jsonp

2017-08-31 16:07 274 查看

一、安装jsonp


"dependencies": {
"vue": "^2.3.3",
"vue-router": "^2.5.3",
"vuex": "^2.3.1",
"fastclick": "^1.0.6",
"vue-lazyload": "1.0.3",
"axios": "^0.16.1",
"jsonp": "0.2.1"
},

二、封装

import originJsonp from 'jsonp'

// 封装一个JSONP
export default function jsonp(url, data, option) {
url += (url.indexOf('?') < 0 ? '?' : '&') + param(data)

return new Promise((resolve, reject) => {
originJsonp(url, option, (err, 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) : ''
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  jsonp javascript vue 封装