亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jquery中用jsonp實現搜索框功能

2019-11-20 08:43:40
字體:
來源:轉載
供稿:網友

前面的話:
    在上周本來想發一篇模仿必應搜索的界面。但是在準備寫文章之前突然想到前面學習了ajax技術,在這里我也讓我的頁面有一種不需要手動刷新就能獲取到數據。但是發現用前面的方法并不能獲取到我想要的效果。無奈前幾天電腦換系統,把之前的源碼丟了(前面有個不好的習慣就是把最近在做的東西放桌面)。今天想徹底把這個問題搞明白。

用jquery和ajax進行初步的嘗試:

(本代碼是參考慕課網,搜索框制作視頻制作,有關具體詳情請參考視頻。自己之前的代碼找不到了,之前最先的想法也是來自那里,所以這次直接用那里的代碼)

html代碼:

 <div class="bg-div">   <div class="search-box">    <div class="logo"></div>    <form id="search-form">     <input type="text" class="search-input-text" autocomplete="off" name="q" id="search_input" />     <input type="submit" class="search-input-button" value="" id="search_submit">    </form>   </div>  </div>    <div class="suggest" id="search-suggest" <!--style="display:none;"-->>   <ul id="search-result">    <li>搜索結果1</li>    <li>搜索結果2</li>   </ul>  </div> 

css代碼:

* {  padding: 0;  margin: 0; }  body {   }  .bg-div{  background-image: url('images/river.jpg');  width: 1228px;  height: 690px;  margin: 0 auto;  position: relative; }  .logo {  background-image: url('images/logo.png');  width: 107px;  height: 53px;  float: left;  margin: -4px 18px 0 0; }  form {  float: left;  background-color: #fff;  padding: 5px; }  .search-input-text {  border: 0;  float: left;  height: 25px;  line-height: 25px;  outline: none;  width: 350px;  font-size: 16px; }  .search-input-button {  border: 0;  background-image: url('images/search-button.png');  width: 29px;  height: 29px;  float: left; }  .search-box {  position: absolute;  top: 200px;  left: 300px; }  #search-suggest {  width: 388px;  background-color: #fff;  border: 1px solid #999;  display: none; }  .suggest ul {  list-style: none; }  .suggest ul li {  padding: 3px;  font-size: 14px;  line-height: 25px;  cursor: pointer;/*手型*/  /*這段代碼去掉 position:absolute; left:----px; top:----px;  */}  .suggest ul li:hover {  text-decoration: underline;  background-color: #e5e5e5; } 

 用jquery來實現效果:
在這之前,我們基本上得到了我們想要的圖形效果,但是我們在搜索框內輸入想要查詢的內容這時候是不會有效果的(一般的搜索框效果都是在鍵盤輸入的時候,下面會顯示一部分與之關聯的關鍵搜索信息,然后鼠標移動上去點擊后會跳到相應鏈接)。為了一步步驗證我們的思路,我們這里修改一下之前的代碼。

1、將li標簽中的定位去掉;

2、在html中將li標簽設置為隱藏。然后我們進行后面的操作。

思考一:如何在鍵盤輸入的時候就顯示相關信息(即:li標簽中的內容)?

思路:我們先引入jquery,然后文檔加載完后執行一個鍵盤事件,然后在鍵盤事件中改變相應的css效果

$(function() { //鍵盤事件 $("#search_input").bind("keyup", function() {    $("#search-suggest").show().css({     top : $("#search-form").offset().top + $("#search-form").height()+10,     left : $("#search-form").offset().left,     position : "absolute",    }); });});

這時候,我們在搜索框中輸入內容時,下面會跟著顯示對應的搜索(模擬)

思考二:如何實現鼠標點擊搜索按鈕的時候,會搜索相應的內容?

思路:用鼠標點擊事件,讓鼠標點擊后設置一個地址,點擊后直接跳到相應地址,代碼實現:

 //事件代理 --》鼠標點擊事件 $(document).delegate("li", "click", function() {  var keyword = $(this).text();  location. + keyword; });

思考三:我們如何在搜索框輸入數據時,下面會提示相關搜素信息?
思路:我們我們用jquery中的get去實現,參考代碼:

  var searchText = $("#search_input").val();  $.get( "http://api.bing.com/qsonhs.aspx?q="+searchText , function(data) {    console.log(data);    var d = data.AS.Results[0].Suggests;    var html = "";    for(var i = 0; i < d.length; i++) {     html += "<li>"+d[i].Txt+"</li>";    }    $("#search-result").html(html);   }   , "json");

到這里,按理來說我們這里應該可以得到我們想要的結果了,但是,找了好久都沒有發現哪里錯了。視頻里面接著描述了用JSONP來進行跨域操作,但是我也按視頻中的操作,始終得不到我想要的結果,于是我埋頭去看《javascript高級程序設計》,去找關于jsonp的用法

關于jsonp:
    關于jsonp,《javascript高級程序設計》一書中介紹的比較少,下面是我看了之后的歸納。
    jsonp的全寫是 json with padding,其出現是為了解決各主瀏覽器的之間的同源策略的問題,一般來說ServerA 域下面的頁面是沒有辦法與非 ServerA 下面的資源進行溝通,而 Html 的<script>元素是個例外,利用 <script> 這個開源策略,網頁可以從其他來源動態獲取 json數據,而這種模式就是所謂的 JSONP,用 jsonp 抓到并不是真正意義上 的 json 而是任意的 javascript ,它是直接通過 javascript 編譯器編譯而不是 json 解釋器。更多關于json的知識請點擊:http://www.cnblogs.com/foodoir/p/5894760.html查看   

既然書上沒有寫,那就去網上搜索資源。這里截取一段和文章前面有關的信息的代碼:

  $.ajax({    type: "get",    async: false,    url: "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998",    dataType: "jsonp",    jsonp: "callback",//傳遞給請求處理程序或頁面的,用以獲得jsonp回調函數名的參數名(一般默認為:callback)        jsonpCallback:"flightHandler",//自定義的jsonp回調函數名稱,默認為jQuery自動生成的隨機函數名,也可以寫"?",jQuery會自動為你處理數據       success: function(json){     alert(json.price + json.tickets + ' 張。');    },    error: function(){     alert('fail');    }   });

通過這段代碼來修改我們自己的代碼:

  $.ajax({   type: "GET",   url: "http://api.bing.com/qsonhs.aspx?type=cb&q=" + searchText,   dataType: "jsonp",   jsonp: 'cb',   success: function(data) {    var d = data.AS.Results[0].Suggests;    var html = "";    for(var i = 0; i < d.length; i++) {     html += "<li>" + d[i].Txt + "</li>";    }    $("#search-result").html(html);    $("#search-suggest").show().css({     top: $("#search-form").offset().top + $("#search-form").height() + 10,     left: $("#search-form").offset().left,     position: "absolute",    });   }  }) 

更多思考:我們可以在前面增加一些判斷,讓我們的效果實現起來更完美

 if(data == null) {     $("#search-suggest").hide();     return false;    }    if(data.AS == null) {     $("#search-suggest").hide();     return false;    }    if(data.AS.Results == null) {     $("#search-suggest").hide();     return false;    }    if(data.AS.Results[0] == null) {     $("#search-suggest").hide();     return false;    }    if(data.AS.Results[0].Suggests == null) {     $("#search-suggest").hide();     return false;    } 

經過測試前面的代碼,發現還有不足,進一步修改代碼:

 $("#search-form").submit(function() {  var keyword = $("#search_input").val();  console.log("word=" + keyword);  //if (keyword == null) {return false;}   location. + keyword; });

到這里,我們的效果差不多就出來了,效果截圖:

源代碼已托管至:http://sandbox.runjs.cn/show/gfdpkysk,點擊即可查看。

后面的話:

  這些天學習的新東西挺多的,現在有一個想法就是把最近學的東西把它串聯起來,做一個綜合的效果。參考必應網站,真的有好多東西已經可以做出來了,接下來的一段時間就好好的把自己想要做的效果實現好。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一色桃子一区二区| 亚洲国产精品小视频| 91精品视频大全| 26uuu另类亚洲欧美日本一| 日韩国产欧美精品在线| 日韩av最新在线| 黑人精品xxx一区一二区| 亚洲色图15p| 亚洲欧美福利视频| 亚洲欧美色图片| 欧美成人激情在线| 91久久国产婷婷一区二区| 91久久精品美女| 欧美天天综合色影久久精品| 国产精品久久久久久久久| 欧美午夜精品伦理| 久久69精品久久久久久久电影好| 免费91麻豆精品国产自产在线观看| 欧美成人精品影院| 亚洲毛片在线观看.| 91精品国产成人www| 98精品在线视频| 亚洲在线www| 亚洲网站视频福利| 欧美国产日韩一区二区| 欧美性黄网官网| 久久久电影免费观看完整版| 国产精品白嫩初高中害羞小美女| 97视频免费在线看| 97国产成人精品视频| 国产日韩换脸av一区在线观看| 国产亚洲精品一区二555| 国产精品一香蕉国产线看观看| 欧美成年人视频网站| 亚洲第一精品久久忘忧草社区| 国产999在线观看| 欧美性视频网站| 国产日韩欧美夫妻视频在线观看| 欧美国产在线电影| 久久久伊人欧美| 亚洲福利在线看| 欧美成人精品xxx| 激情亚洲一区二区三区四区| 成人自拍性视频| 91午夜理伦私人影院| 一本大道久久加勒比香蕉| 久久久久久综合网天天| 欧美电影在线观看完整版| 欧美成人在线影院| 中文字幕成人精品久久不卡| 亚洲国产精品99久久| 日韩禁在线播放| 国产成人精品在线播放| 欧美噜噜久久久xxx| 国产欧美婷婷中文| 亚洲有声小说3d| 久久99久国产精品黄毛片入口| 国产精品成人久久久久| 色噜噜久久综合伊人一本| 日韩电影在线观看中文字幕| 欧美激情视频三区| 日产精品久久久一区二区福利| 日韩精品高清在线| 国产精品igao视频| 欧美精品在线免费播放| 福利微拍一区二区| 欧美成人精品一区二区三区| 欧美成人精品在线观看| 国产亚洲精品一区二555| 亚洲色图美腿丝袜| 精品国产一区二区三区久久狼5月| 91成人在线播放| 亚洲一区二区三区在线免费观看| 日韩av电影在线免费播放| 欧美午夜影院在线视频| 91影视免费在线观看| 成人欧美在线观看| 欧美大片欧美激情性色a∨久久| 欧洲日韩成人av| 亚洲成人a**站| 日韩亚洲欧美成人| 不卡在线观看电视剧完整版| 国产成人久久精品| 欧美日韩激情美女| 色偷偷av亚洲男人的天堂| 日韩精品在线影院| 欧美老女人性生活| 在线日韩中文字幕| 78m国产成人精品视频| 欧美精品电影免费在线观看| 中文字幕国产亚洲| 亚洲精品视频免费在线观看| 亚洲色图25p| 欧美精品国产精品日韩精品| 成人精品一区二区三区电影免费| 欧美激情视频在线免费观看 欧美视频免费一| 欧美日韩在线一区| 欧美做受高潮1| 亚洲人成在线观| 国产乱肥老妇国产一区二| 91精品久久久久久久久不口人| 国产伊人精品在线| 色噜噜国产精品视频一区二区| 92版电视剧仙鹤神针在线观看| 日韩精品极品在线观看| 国产精品福利在线观看网址| 国产精品偷伦一区二区| 日韩av电影免费观看高清| 欧美日韩国产中文字幕| 精品动漫一区二区三区| 国产精品一二三视频| 久久国产精品电影| 亚洲成年人在线播放| 日韩精品一二三四区| 精品福利在线视频| 国产日韩欧美综合| 久久影院资源网| 亚洲欧美日韩图片| 26uuu另类亚洲欧美日本一| 国产精品麻豆va在线播放| 精品综合久久久久久97| 欧美成人精品一区| www.亚洲一区| 日韩人在线观看| 亚洲护士老师的毛茸茸最新章节| 久久综合电影一区| 午夜精品久久久久久久99热浪潮| 7m精品福利视频导航| 成人精品一区二区三区电影免费| 国产一区红桃视频| 亚洲欧洲一区二区三区久久| 亚洲欧美福利视频| 2019中文字幕在线观看| 国产精品一区二区久久| 国产精品人人做人人爽| 91免费人成网站在线观看18| 丝袜美腿精品国产二区| 日韩在线观看视频免费| 青青草99啪国产免费| 奇门遁甲1982国语版免费观看高清| 97超碰色婷婷| 亚洲伊人一本大道中文字幕| 亚洲性夜色噜噜噜7777| 欧美精品18videosex性欧美| 亚洲第一男人av| 亚洲精品日韩久久久| 亚洲最大福利视频| 欧美日韩国产在线| 国产成人鲁鲁免费视频a| 久久久久久午夜| 5566成人精品视频免费| 成人网在线观看| 欧美激情小视频| 国产精品国产亚洲伊人久久| 久久成人免费视频| 中文字幕亚洲精品| 91高清视频在线免费观看| 日韩成人中文字幕| 萌白酱国产一区二区| 久久久久久久久久亚洲| 性欧美长视频免费观看不卡| 欧美成人手机在线| 日韩精品在线观| 日韩成人黄色av|