jsonp跨域獲取百度聯(lián)想詞的方法分析
本文實例講述了jsonp跨域獲取百度聯(lián)想詞的方法。分享給大家供大家參考,具體如下:
jsonp原理:
1.Web頁面上用<script> 引入 js文件時則不受是否跨域的影響 (不僅如此,我們還發(fā)現(xiàn)凡是擁有"src"這個屬性的標(biāo)簽都擁有跨域的能力,比如<script>、<img>、<iframe>)
2.于是我們把數(shù)據(jù)放到服務(wù)器上,并且數(shù)據(jù)為json形式(因為js可以輕松處理json數(shù)據(jù))
3.因為我們無法監(jiān)控通過<script>的src屬性是否把數(shù)據(jù)獲取完成,所以我們需要做一個處理。
4.實現(xiàn)定義好處理跨域獲取數(shù)據(jù)的函數(shù),如 function doJson(data){}。
5.用src獲取數(shù)據(jù)的時候添加一個參數(shù)cb=‘doJson' (服務(wù)端會根據(jù)參數(shù)cb的值返回對應(yīng)的內(nèi)容) 此內(nèi)容為以cb對應(yīng)的值,doJson為函數(shù)真實要傳遞的數(shù)據(jù)為函數(shù)的參數(shù)的一串字符如 doJson('數(shù)據(jù)')
百度聯(lián)想詞的實現(xiàn):
用jsonp解決跨域問題。我們就跨域拿到百度的數(shù)據(jù)
<script>
//輸入框
var oInp = document.getElementsByTagName('input')[0];
//得到的數(shù)據(jù)存在ul的li里
var oUl = document.getElementsByTagName('ul')[0];
//獲取輸入內(nèi)容,查找百度對應(yīng)的src
oInp.oninput = function () {
var value = this.value;
var oScript = document.createElement('script');
oScript.src = 'https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=' + value + '&cb=doJosn';
document.body.appendChild(oScript);
}
//對傳回的數(shù)據(jù)進行處理(回調(diào)函數(shù))
function doJosn(data) {
var s = data.s;
var str = '';
if (s.length > 0) {
s.forEach(function (ele, index) {
str += '<li><a href =https://sp0.baidu.com/s?wd=' + ele + '>' + ele + '</a></li>';
})
oUl.innerHTML = str;
oUl.style.display = 'block';
} else {
oUl.style.display = 'none';
}
}
</script>
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
javascript使用appendChild追加節(jié)點實例
這篇文章主要介紹了javascript使用appendChild追加節(jié)點的方法,實例分析了appendChild()函數(shù)增加結(jié)點的使用技巧,需要的朋友可以參考下2015-01-01
curring的概念將函數(shù)式編程的概念和默認(rèn)參數(shù)以及可變參數(shù)結(jié)合在一起.一個帶n個參數(shù),curried的函數(shù)固化第一個參數(shù)為固定參數(shù),并返回另一個帶n-1個參數(shù)的函數(shù)對象,分別類似于LISP的原始函數(shù)car和cdr的行為。currying能泛化為偏函數(shù)應(yīng)用(partial function application, PFA),p 這種函數(shù)將任意數(shù)量(順序)的參數(shù)的函數(shù)轉(zhuǎn)化為另一個帶剩余參數(shù)的函數(shù)對象2012-02-02
談?wù)処ntersectionObserver懶加載的具體使用
這篇文章主要介紹了談?wù)処ntersectionObserver懶加載的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
js toFixed()方法的重寫實現(xiàn)精度的統(tǒng)一
凡用過js 中的toFix() 方法的, 應(yīng)該都知道這個方法存在一個小小的BUG,在IE 下和FF 下對于小數(shù)的進位有點不同2014-03-03
利用 JavaScript 實現(xiàn)并發(fā)控制的示例代碼
這篇文章主要介紹了利用 JavaScript 實現(xiàn)并發(fā)控制的示例代碼,本文通過實例代碼給大家介紹的非常想詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12

