使用Jest框架測試一段jsonp的代碼, 但是Jest使用的JsDom好像無法加載script標(biāo)簽的內(nèi)容, 導(dǎo)致jsonp的全局函數(shù)無法被調(diào)用. 故不能很好的對這段jsonp進(jìn)行單側(cè).
jsonp的代碼如下:
function noop(){}
/**
* @description 序列化數(shù)據(jù)
*/
function formatParams(data) {
let arr = [];
for (let name in data) {
arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));
}
return arr.join("&");
}
/**
* @description jsopn請求函數(shù)
* @param {string} url: 請求地址
* @param {object} opts: 請求配置項(xiàng)
* {object}} parmas: 動(dòng)參請求數(shù)據(jù)的對象
* {number} timeout: 延遲的時(shí)間
* @param {function} fn 回調(diào)函數(shù), 參數(shù)分別為rr, data
*/
function jsonp(url, opts, fn){
// 獲取隨機(jī)數(shù)
const random = Math.random().toString().replace('.', '');
// 基礎(chǔ)的回調(diào)名稱
const baseCbName = '__onDWGetData__'
// 獲取了隨機(jī)數(shù)后的回調(diào)名稱
const id = baseCbName + random;
// 需要被添加到參數(shù)字符串的后綴, 動(dòng)態(tài)參數(shù)會(huì)根據(jù)jsonpCallback的值返回函數(shù)名
const suffix = '&jsonpCallback=' + baseCbName + random;
// 進(jìn)行數(shù)據(jù)的序列化, 隨后添加上&jsonpCallback的后綴
const param = formatParams(opts.data) + suffix;
// 生成script標(biāo)簽的url, https://dw-online.ksosoft.com/api/dynamicParam/v1/app/appKey + '?' + 序列化的參數(shù)
url += '?' + param;
// 延遲
const timeout = null != opts.timeout ? opts.timeout : 60000;
const target = document.head;
let script;
let timer;
if (timeout) {
timer = setTimeout(function(){
cleanup();
if (fn) fn(new Error('ReqDynamic params Timeout'));
}, timeout);
}
function cleanup(){
if (script.parentNode) script.parentNode.removeChild(script);
window[id] = noop;
if (timer) clearTimeout(timer);
}
function cancel(){
if (window[id]) {
cleanup();
}
}
window[id] = function(data){
cleanup();
console.log('window全局調(diào)用了函數(shù):', fn, data);
if (fn) fn(null, data);
};
// 創(chuàng)建腳本
script = document.createElement('script');
script.src = url;
target.parentNode.insertBefore(script, target);
return cancel;
}
export { jsonp };
測試的偽代碼代碼如下:
import { jsonp } from '../src/jsonP';
test('模擬jsonp實(shí)現(xiàn)', done => {
jsonp('https://fake-collect.com', {a: 'b'}, (err, data) => {
expect(data).toBeTruthy();
done();
})
})
但是每次都會(huì)拋出jsonp代碼中的Error: ReqDynamic params Timeout錯(cuò)誤, 該錯(cuò)誤代表請求超時(shí). 表明script無法被正確的加載導(dǎo)致.
能夠在Jest框架中正確的運(yùn)行jsonp的整個(gè)過程, 加載script`標(biāo)簽和全局函數(shù)被調(diào)用的過程
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。