jq使用jsonp實現百度搜索

来源:https://www.cnblogs.com/cpfblogs/archive/2020/05/10/12865456.html
-Advertisement-
Play Games

項目實現:還原百度搜索功能; 項目原理:利用json回調頁面傳參; 什麼是jsonp:就是利用<script>標簽的src地址,讓目標頁面回調本地頁面,並且帶入參數,也解決了跨域問題; 代碼如下: html(css代碼不提供) 1 <div class="box"> 2 <input type="t ...


項目實現:還原百度搜索功能;

項目原理:利用json回調頁面傳參;

什麼是jsonp就是利用<script>標簽的src地址,讓目標頁面回調本地頁面,並且帶入參數,也解決了跨域問題;

代碼如下:

html(css代碼不提供)

1 <div class="box">
2       <input type="text" />
3       <div class="ssk"></div>
4       <button>×</button>
5 </div>

js

 1 var script,ids;
 2       $(".box>input").on("input",inputHandler)
 3       function inputHandler(e){
 4         if (ids) return;
 5         ids = setTimeout(function () {//節流
 6           clearTimeout(ids);
 7           ids=0;
 8           if (script) { //刪除上一次創建script標簽
 9             script.remove();
10             script = null;
11           }
12           script=$("<script><\/script>").attr("src",`https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd= 
13                ${$(".box>input").val()}
            &json=1&p=3&sid=22084_1436_13548_21120_22036_22073&req=2&csor=0&cb=callback` 14 ).appendTo("body"); 15 // 點擊x按鈕刪除搜索框內容,並且隱藏button按鈕 16 $("button").click(function () { 17 $("input").val(""); 18 $("button").css("display", "none"); 19 }); 20 // 如果搜索框為空則把x按鈕隱藏 21 if ($("input").val().length === 0) { 22 $("button").css("display", "none"); 23 } else { 24 $("button").css("display", "block"); 25 } 26 27 }, 500); 28 } 29 function callback(data) { 30 if (data) { 31 $(".box>.ssk").css("display", "block"); 32 } 33 // 刪除上一次的搜索列表 34 if ($(".ssk").children().length !== 0) { 35 $("a").remove(); 36 } 37 // 遍曆數組內容輸出 38 $.each(data.s, function (index, item) { 39 $("<a>"+item+"</a>").appendTo(".box>.ssk"); 40 $("a").attr('href','https://www.baidu.com/s?tn=02003390_43_hao_pg&isource=infinity&wd='+encodeURIComponent(item)); 41 }); 42 // 失去焦點隱藏搜索列表 43 $(".box>.ssk").on("mouseleave", function () { 44 $(".box>.ssk").css("display", "none"); 45 }); 46 }
  • 這裡目標頁面是“https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=&json=1&p=3&sid=22084_1436_13548_21120_22036_22073&req=2&csor=0&cb=callback” 向百度伺服器請求
  • callback函數為目標伺服器的回調函數,傳回來的參數data是一個對象;
  • callback回調函數中,傳回來的data中s屬性是搜索到的內容,遍歷data.s數組,將每個元素的外層添加a標簽,a標簽的超鏈接為搜索到的內容,
  • 改變a標簽超鏈接的wd屬性就可以搜索到對應的內容;wd傳入的值需要進行編碼(encodeURIComponent)處理,伺服器才能給出對應內容的超鏈接

日常百度搜索都有wd屬性,改變wd屬性即可得到搜索

 

 

 

最終效果:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言: 本文詳細介紹了 HBase FamilyFilter 過濾器 Java&Shell API 的使用,並貼出了相關示例代碼以供參考。FamilyFilter 基於列族進行過濾,在工作中涉及到需要通過HBase 列族進行數據過濾時可以考慮使用它。比較器細節及原理請參照之前的更文: "HBase ...
  • SDS 簡單動態字元串。 SDS的結構: struct sdshdr{ int len;//記錄BUF數組中已使用位元組的數量 ,等於SDS所八寸字元串的長度 int free;//記錄BUF數組中未使用位元組的數量 char buf[];//位元組數組,用於保存字元串 } 1、與c語言的字元串相比,SD ...
  • 1、讀取Mysql數據 object JdbcRddDemo { def getConn() = { Class.forName("com.mysql.jdbc.Driver").newInstance() DriverManager.getConnection("jdbc:mysql://hado ...
  • 表結構 student(StuId,StuName,StuAge,StuSex) 學生表 teacher(TId,Tname) 教師表 course(CId,Cname,C_TId) 課程表 sc(SId,S_CId,Score) 成績表 問題八:查詢課程編號“002”的成績比課程編號“001”課程 ...
  • 1. 下載上傳安裝包到伺服器 下載鏈接: "https://pan.baidu.com/s/1YNaEq9E8lugXC8ebKyegwA" 提取碼:ienf 2. 解壓及創建目錄 解壓 tar xzvf mysql 5.7.11 linux glibc2.5 x86_64.tar.gz 重命名 m ...
  • 廣播變數 應用場景:在提交作業後,task在執行的過程中, 有一個或多個值需要在計算的過程中多次從Driver端拿取時,此時會必然會發生大量的網路IO, 這時,最好用廣播變數的方式,將Driver端的變數的值事先廣播到每一個Worker端, 以後再計算過程中只需要從本地拿取該值即可,避免網路IO,提 ...
  • NDK clang編譯器的一個bug 問題代碼 ...
  • 本系列的目的是幫助更多面試經驗不足的前端人才更好地展現自己。在此,我分享一些以往我參加面試和參與招聘的一些心得,希望對大家有幫助。 關於簡歷設計 簡歷是人才的縮影,一份優質的簡歷是前往大公司的敲門磚。所以對於招聘,簡歷準備是第一環,也是最重要的一環。前端工程師的簡歷其實不需要視覺設計類的那般花哨,核 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...