jQuery使用jsonp實(shí)現(xiàn)百度搜索的示例代碼
項(xiàng)目實(shí)現(xiàn):還原百度搜索功能;
項(xiàng)目原理:利用json回調(diào)頁(yè)面?zhèn)鲄?
什么是jsonp:就是利用<script>標(biāo)簽的src地址,讓目標(biāo)頁(yè)面回調(diào)本地頁(yè)面,并且?guī)雲(yún)?shù),也解決了跨域問(wèn)題;
代碼如下:
html(css代碼不提供)
<div class="box"> <input type="text" /> <div class="ssk"></div> <button>×</button> </div>
js
var script,ids; $(".box>input").on("input",inputHandler) function inputHandler(e){ if (ids) return; ids = setTimeout(function () {//節(jié)流 clearTimeout(ids); ids=0; if (script) { //刪除上一次創(chuàng)建script標(biāo)簽 script.remove(); script = null; } script=$("<script><\/script>").attr("src",`https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd= ${$(".box>input").val()} &json=1&p=3&sid=22084_1436_13548_21120_22036_22073&req=2&csor=0&cb=callback` ).appendTo("body"); // 點(diǎn)擊x按鈕刪除搜索框內(nèi)容,并且隱藏button按鈕 $("button").click(function () { $("input").val(""); $("button").css("display", "none"); }); // 如果搜索框?yàn)榭談t把x按鈕隱藏 if ($("input").val().length === 0) { $("button").css("display", "none"); } else { $("button").css("display", "block"); } }, 500); } function callback(data) { if (data) { $(".box>.ssk").css("display", "block"); } // 刪除上一次的搜索列表 if ($(".ssk").children().length !== 0) { $("a").remove(); } // 遍歷數(shù)組內(nèi)容輸出 $.each(data.s, function (index, item) { $("<a>"+item+"</a>").appendTo(".box>.ssk"); $("a").attr('href','https://www.baidu.com/s?tn=02003390_43_hao_pg&isource=infinity&wd='+encodeURIComponent(item)); }); // 失去焦點(diǎn)隱藏搜索列表 $(".box>.ssk").on("mouseleave", function () { $(".box>.ssk").css("display", "none"); }); }
- 這里目標(biāo)頁(yè)面是“https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=&json=1&p=3&sid=22084_1436_13548_21120_22036_22073&req=2&csor=0&cb=callback” 向百度服務(wù)器請(qǐng)求
- callback函數(shù)為目標(biāo)服務(wù)器的回調(diào)函數(shù),傳回來(lái)的參數(shù)data是一個(gè)對(duì)象;
- callback回調(diào)函數(shù)中,傳回來(lái)的data中s屬性是搜索到的內(nèi)容,遍歷data.s數(shù)組,將每個(gè)元素的外層添加a標(biāo)簽,a標(biāo)簽的超鏈接為搜索到的內(nèi)容,
- 改變a標(biāo)簽超鏈接的wd屬性就可以搜索到對(duì)應(yīng)的內(nèi)容;wd傳入的值需要進(jìn)行編碼(encodeURIComponent)處理,服務(wù)器才能給出對(duì)應(yīng)內(nèi)容的超鏈接
日常百度搜索都有wd屬性,改變wd屬性即可得到搜索
最終效果:
以上就是jQuery使用jsonp實(shí)現(xiàn)百度搜索的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于jQuery實(shí)現(xiàn)百度搜索的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
jQuery實(shí)現(xiàn)新消息閃爍標(biāo)題提示的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)新消息閃爍標(biāo)題提示的方法,實(shí)例分析了jQuery操作樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03初窺JQuery-Jquery簡(jiǎn)介 入門(mén)了解篇
JQuery是一種非常靈活的腳本庫(kù),JQuery庫(kù)為Web腳本編程提供了通用的抽象層,已經(jīng)是比較流行的js框架了。2010-11-11初窺JQuery(一)jquery選擇符 必備知識(shí)點(diǎn)
JQuery強(qiáng)大的選擇符可以讓我們獲得頁(yè)面中任何元素進(jìn)行操作,并且使用簡(jiǎn)單方便,可讀性強(qiáng)。2010-11-11javascript的變量、傳值、傳址、參數(shù)之間關(guān)系
這篇文章主要介紹了javascript的變量、傳值、傳址、參數(shù)之間關(guān)系的相關(guān)資料,需要的朋友可以參考下2015-07-07Jquery回調(diào)對(duì)象與延遲對(duì)象用法詳解
本文詳細(xì)講解了Jquery回調(diào)對(duì)象與延遲對(duì)象的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05jquery對(duì)Json的各種遍歷方法總結(jié)(必看篇)
下面就為大家?guī)?lái)一篇jquery對(duì)Json的各種遍歷方法總結(jié)(必看篇)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09jQuery 獲取除某指定對(duì)象外的其他對(duì)象 ( :not() 與.not())
這篇文章主要介紹了JQuery 獲取除某指定對(duì)象外的其他對(duì)象 ( :not() 與.not()),需要的朋友可以參考下2018-10-10jQuery html()方法使用不了無(wú)法顯示內(nèi)容的問(wèn)題
jquery中的html方法使用不了,只能用完最基本的innerHTML把內(nèi)容展示出來(lái)2014-08-08