首頁 web前端 js教程 實作無刷新下拉動聯動的Ajax+Servlet(附程式碼)

實作無刷新下拉動聯動的Ajax+Servlet(附程式碼)

Mar 30, 2018 pm 04:57 PM
下拉 聯動

這次帶給大家實現無刷新下拉動的Ajax+Servlet(附程式碼),實現實現無刷新下拉動聯動的Ajax+Servlet的注意事項有哪些,下面就是實戰案例,一起來看一下。

下拉動連動的功能可以說非常的常用,例如在選擇省、市等資訊的時候;或是在選擇大類、小類的時候。總之,下拉動聯動很常用。今天就跟大家分享一個簡單的二級下拉動連動的功能。

大類下拉框:頁面載入的時候就初始化大類的下拉選項,透過後台程式碼去資料庫裡面取得資料(當然像省市這樣不變的內容可以直接給值),然後載入到下拉選項中。

<select name="region" class="select1" id="BigClass" onchange="selectProv(this)"> 
  <option value="0">--全部--</option> 
  <% 
    Map map = ClientManager.getInstance().getRegionList(); 
    for (Iterator iter=map.entrySet().iterator(); iter.hasNext();) { 
      Map.Entry entry = (Map.Entry)iter.next();                     
  %> 
      <option value="<%=entry.getKey() %>"><%=entry.getValue() %></option> 
  <% 
    } 
  %>   
</select>
登入後複製

小類下拉框:小類的下拉選項是透過Ajax將所選大類的內容非同步提交到一個Servlet,然後傳回對應的小類內容,最後載入到小類下拉選項中。

<select name="province" class="select1" id="SmallClass"> 
  <option value="0">--全部--</option> 
</select>
登入後複製

取得並載入小類下拉框的JS程式碼:

<script type="text/javascript"> 
  function selectProv(field) { 
    var xmlHttp = null; 
    //表示当前浏览器不是ie,如ns,firefox 
    if(window.XMLHttpRequest) { 
      xmlHttp = new XMLHttpRequest(); 
    } else if(window.ActiveXObject) { 
      xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); 
    } 
      var url = "${pageContext.request.contextPath}/servlet/SelectProvServlet?regionId=" + trim(field.value) + "&time=" + new Date().getTime(); 
     
    //设置请求方式为GET,设置请求的URL,设置为异步提交 
    xmlHttp.open("GET", url, true); 
     
    xmlHttp.onreadystatechange=function() { 
      //Ajax引擎状态为成功 
      if(xmlHttp.readyState == 4) { 
        //HTTP协议状态为成功 
        if(xmlHttp.status == 200) { 
          var doc = xmlHttp.responseXML; 
          var items = doc.getElementsByTagName("item"); 
          //取得小类下拉列表 
          var provSelect = document.getElementById("SmallClass"); 
          //清除小类下拉列表中的值 
          provSelect.options.length = 0; 
          var o = new Option("--全部--", 0); 
          provSelect.add(o); 
          for (var i=0; i<items.length; i++) { 
            var id =items[i].childNodes[0].firstChild.nodeValue; 
            var name = items[i].childNodes[1].firstChild.nodeValue; 
            var o = new Option(name, id); 
            provSelect.add(o); 
          } 
        }else { 
          alert("请求失败,错误码=" + xmlHttp.status); 
        } 
      } 
    }; 
     
    //将设置信息发送到Ajax引擎 
    xmlHttp.send(null); 
  } 
</script>
登入後複製

具體怎麼從資料庫取資料就不在這裡贅述了,就是一個普通的查詢,比較簡單。二級連動、三級連動、多級連動都是一樣的,就是預先載入一個下拉框的內容,然後,根據第一個的所選內容載入後面的下拉框選項,以此類推。掌握了二級聯動,其他的也就不在話下了,也就是多加幾個下拉框的事兒。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

在ajax中用josnp接收josn資料步驟詳解

前端ajax請求的優雅方案怎麼實作

以上是實作無刷新下拉動聯動的Ajax+Servlet(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

旅程IPx經典動畫《西遊記》 西行旅程無畏無懼 旅程IPx經典動畫《西遊記》 西行旅程無畏無懼 Jun 10, 2024 pm 06:15 PM

穿越蒼茫征途,踏足西遊之境!今日,征途IP正式宣布將與央視動畫《西遊記》展開跨界合作,共同打造一場融合了傳統與創新的文化盛宴!此次攜手,不僅標誌著兩大國產經典品牌的深度合作,更彰顯了征途系列在弘揚中國傳統文化道路上的不懈努力與堅持。征途系列自誕生以來,便憑藉其深厚的文化底蘊和多元化的遊戲玩法,受到玩家們的喜愛。在文化傳承方面,征途系列更是始終保持著對中國傳統文化的敬意與熱愛,將傳統文化元素巧妙地融入遊戲,為玩家們帶來了更多的樂趣與啟發。而央視動畫《西遊記》則是陪伴了一代又一代人成長的經典之作,其

雙廚狂喜! 《陰陽師》X《初音未來》連動3月6日開啟 雙廚狂喜! 《陰陽師》X《初音未來》連動3月6日開啟 Feb 22, 2024 pm 06:52 PM

網易《陰陽師》手遊在今日宣布,陰陽師×初音未來限定連動將於3月6日正式開始。連動限定SSR初音未來(CV:藤田咲)、SSR鏡音鈴連(CV:下田麻美)即將降臨平安京!連動線上特別演出活動3月9日於遊戲內正式開啟~

炸雞大業,不容差池! 《逆水寒》聯動肯德基福上天,玩家社死'聞雞起舞” 炸雞大業,不容差池! 《逆水寒》聯動肯德基福上天,玩家社死'聞雞起舞” Apr 17, 2024 pm 06:34 PM

日期,《逆水寒》官宣將於4月19號-5月12號與肯德基展開聯動,但聯動的具體內容卻讓許多人蚌埠住了,連番直說「民上天了」、「要社死了」!原因就出在這次主題活動的口號上,曾經見識過《原神》《崩鐵》肯德基聯動的小伙伴肯定有印象,什麼“異世相遇、盡享美味”,到了《逆水寒》這裡就成了:對店員喊出「神候府查案,爾等何人?」店員需回答「炸雞大業,不容差池!」對員工的訓練指南:絕對不能笑!不只這個,這次聯動還辦起了舞蹈大賽,到主題店做出「聞『基』起舞」舞蹈動作,還能獲得一個搖搖樂小立牌。民,太民了!但就是要這

經典重聚,逆轉時空《天龍2》X《大話西遊》電影連結決定 經典重聚,逆轉時空《天龍2》X《大話西遊》電影連結決定 Mar 28, 2024 pm 04:40 PM

經典重聚,逆轉時空。 《天龍2》手遊與經典電影《大話西遊》攜手定檔4月11日!恰逢《天龍2》手遊週年慶典,邀請大家共同重溫經典回憶,再次見證至尊寶與紫霞至死不渝的傳奇故事。七彩祥雲要有,金甲聖衣也要有當那句「般若波羅蜜」迴盪在耳邊時,你是否會想起紫霞留在至尊寶心底的那一滴眼淚?一眼萬年,卻難逃宿命之劫。縱使萬劫不復,吾愛至死不渝。大話西遊連結外觀【一眼萬年】【天意】將隨週年慶版本同步上線。願你可以身披金甲聖衣又或可以邂逅自己的蓋世英雄,重回至情至性的青春年少。五百年守護,真愛至死不渝那日偶遇洛陽說

Java開發表單欄位的連動與依賴功能 Java開發表單欄位的連動與依賴功能 Aug 07, 2023 am 08:41 AM

Java開發表單欄位的連結與依賴功能引言:在Web開發中,表單是經常使用到的互動方式,使用者可以透過表單填寫資訊並提交,而繁瑣、冗餘的表單欄位選擇作業往往會給用戶帶來不便。因此,表單欄位的連動和依賴功能被廣泛應用於提升使用者體驗和操作效率。本文將介紹如何使用Java開發實作表單欄位的連動和依賴功能,並提供對應的程式碼範例。一、表單欄位聯動功能的實作表單

《暗黑破壞神:不朽》X《仙劍奇俠傳》聯動決定! 《暗黑破壞神:不朽》X《仙劍奇俠傳》聯動決定! Apr 17, 2024 pm 02:58 PM

網易遊戲在今天宣布,《暗黑破壞神:不朽》決定聯動《仙劍奇俠傳》。 4月24日「一劍逍遙」開啟不朽修仙新時代!一個是西方魔幻的經典之作,一個是東方仙俠的永恆回憶,暗黑宇宙與仙劍江湖時空交錯,兩大IP攜手斬妖除魔。 4月24日,關於正義與俠道的不滅傳說將在庇護之地上演!

元夢之星奧特曼正版連動:賽羅澤塔共鳴奧特之力,迸發熱血火花! 元夢之星奧特曼正版連動:賽羅澤塔共鳴奧特之力,迸發熱血火花! Feb 24, 2024 pm 02:25 PM

元夢之星奧特曼正版聯動系列,賽羅澤塔同款時裝細節今日大公開,相信大家已經期待很久了,與賽羅澤塔聯名時裝已於今日上線,一起跟隨小編來看看本次奧特曼聯動的更多細節,希望能帶給你幫助。元夢之星奧特曼正版連動:賽羅澤塔共鳴奧特之力,迸發熱血火花!賽羅作為光之國新一代的年輕奧特戰士終極賽羅警備隊的隊長賽羅奧特曼不羈又善良,熱情又奔放「有我在身邊,你還不放心嗎?賽羅會盡全力保護星寶星寶們快穿上賽羅奧特曼時裝,與賽羅一起奮勇戰鬥吧!細節展示建模動作展示出場動作待機動作澤塔我才不是三分之一的半吊子,我是宇宙

如何結合ECharts和php介面實現多圖表連動的統計圖展示 如何結合ECharts和php介面實現多圖表連動的統計圖展示 Dec 18, 2023 am 10:07 AM

在資料視覺化的領域中,ECharts作為一款被廣泛使用的前端圖表庫,其強大的資料視覺化功能受到了各行業的追捧。在實際專案中,經常會遇到需要對多個圖表進行連動展示的情況,本文將介紹如何結合ECharts和PHP介面實現多圖表連動的統計圖展示,並給出具體的程式碼範例。一、前置技能在本文的實踐中,需要掌握以下技能:HTML、CSS、JavaScript的基礎知識;

See all articles