使用Jest框架測(cè)試一段jsonp
的代碼, 但是Jest使用的JsDom好像無(wú)法加載script
標(biāo)簽的內(nèi)容, 導(dǎo)致jsonp
的全局函數(shù)無(wú)法被調(diào)用. 故不能很好的對(duì)這段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請(qǐng)求函數(shù)
* @param {string} url: 請(qǐng)求地址
* @param {object} opts: 請(qǐng)求配置項(xiàng)
* {object}} parmas: 動(dòng)參請(qǐng)求數(shù)據(jù)的對(duì)象
* {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)名稱(chēng)
const baseCbName = '__onDWGetData__'
// 獲取了隨機(jī)數(shù)后的回調(diào)名稱(chēng)
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 };
測(cè)試的偽代碼代碼如下:
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ò)誤代表請(qǐng)求超時(shí). 表明script
無(wú)法被正確的加載導(dǎo)致.
能夠在Jest框架中正確的運(yùn)行jsonp的整個(gè)過(guò)程, 加載
script`標(biāo)簽和全局函數(shù)被調(diào)用的過(guò)程
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專(zhuān)業(yè)的國(guó)家
北大青鳥(niǎo)中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(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é)及管理工作。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。