В свободное время, чтобы иметь больше возможностей data vue и es6, я научился и сделал проект мобильного веб-приложения vue. В проекте также было много проблем.
Далее поговорим о том, как выполнить это требование, а затем поговорим о проблемах, с которыми я столкнулся, чтобы исправить ошибки.
Первый шаг, затем представил проект vuejsonp
, А такжеjsonp
упаковка.
использоватьnpm
Введение, введите:
npm install jsonp --save
package.json
文件中查看是否有此依赖。 Как показано ниже:
Если в красном поле отображается содержимое, установка прошла успешно, и следующим шагом будет инкапсуляция:
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.
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
документ:
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)
}
Последние данные данных:
Затем последний шаг — запросить данные в файле .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
}
})
},
}
}
Если браузер возвращает содержимое, показанное на следующей картинке на странице, это означает успех.
Уведомление:Яма, обнаруженная в проекте
1: При запросе данных возникает ситуация, показанная на следующем снимке экрана:
После долгих поисков причины я, наконец, обнаружил, что это было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.