本身利用業餘時間,爲了更加數據vue和es6的特性,自學着和作了vue的移動端webapp項目。在項目中也是遇到了不少的問題。vue
接下來,先說一下怎麼實現這個需求,而後再說我遇到的問題,以用來糾錯。es6
第一步,再vue項目中引入jsonp
,並進行jsonp
的封裝。web
使用npm
引入,輸入:npm
npm install jsonp --save複製代碼
安裝好以後能夠在本身的package.json
文件中查看是否有此依賴。以下圖所示:json
若是有紅框中顯示的內容,說明安裝成功,進入下一步封裝:api
import originJSONP from 'jsonp' //引入jsonp
//進行封裝並export
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)
}
})
})
}
//對data進行處理,並encodeURIComponent()進行轉碼。
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.js
文件以後,進入第二步:瀏覽器
在項目文件中配置須要的api
。第一個api
,命名爲config.js.
bash
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 //設置屬性
複製代碼
而後再建立一個recommend.js
的文件:app
import jsonp from 'common/js/jsonp' //引入jsonp
import {commonParams,options} from './config' //引入config.js
export function getRecommend(){
const url = 'https://c.y.qq.com/musichall/fcgi-bin/fcg_yqqhomepagerecommend.fcg'
const data = Object.assign({},commonParams,{ //es6的assign將commonParams和
uin: 0, //以後的對象合併爲一塊兒,放在
platform:'h5', //前面的{}之中。
needNewCode: 1,
})
return jsonp(url,data,options)
}
複製代碼
其中的data最後的數據爲:webapp
而後,最後一步,就是在項目中所須要的.vue文件中去請求數據啦。
import {getRecommend} from 'api/recommend' //引入recommend.js中的getRecomend方法
import {ERR_OK} from 'api/config' //引入recommend.js中的getRecomend方法
import Slider from 'base/slider/slider'
export default {
data() {
return{
recommends : []
}
},
created(){
this._getRecommend()
},
methods:{
_getRecommend() {
getRecommend().then((res)=>{
if(res.code === ERR_OK){
this.recommends = res.data.slider
}
})
},
}
}
複製代碼
若是在頁面中瀏覽器返回如下圖片所示的內容,就說明成功啦。
注意:在項目中遇到的坑
一:在請求數據的時候遇到如下截圖所示的狀況:
找緣由找了很久,最後才發現是encodeURIComponent()這裏出錯了。注意不能寫成
、url += '&' + k + '=' + encodeURIComponent(value)、複製代碼
有可能不支持es6這樣的語法。應該寫成
for(var k in data) {
let value = data[k] !== undefined? data[k] : ''
url += '&' + k + '=' + encodeURIComponent(value)
}複製代碼
第二點:關於地址
const url = 'https://c.y.qq.com/musichall/fcgi-bin/fcg_yqqhomepagerecommend.fcg'複製代碼
不能寫成
const url = 'https://m.y.qq.com/musichall/fcgi-bin/fcg_yqqhomepagerecommend.fcg'複製代碼
好啦,就總結這麼多啦。請求到數據以後,就是一些基本的DOM操做啦。