欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js使用xml數(shù)據(jù)載體實(shí)現(xiàn)城市省份二級(jí)聯(lián)動(dòng)效果

 更新時(shí)間:2021年08月24日 16:30:56   作者:evan_qb  
這篇文章主要為大家詳細(xì)介紹了js使用xml數(shù)據(jù)載體實(shí)現(xiàn)城市省份二級(jí)聯(lián)動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了使用xml數(shù)據(jù)載體實(shí)現(xiàn)城市省份二級(jí)聯(lián)動(dòng)的具體代碼,供大家參考,具體內(nèi)容如下

首先寫好前臺(tái)頁面testProvince.jsp,將請(qǐng)求通過open、send發(fā)送到服務(wù)器

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
<% 
String path = request.getContextPath(); 
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; 
%> 
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
<html> 
 <head> 
 <base href="<%=basePath%>" rel="external nofollow" > 
 <title>二級(jí)聯(lián)動(dòng)</title> 
 <meta http-equiv="pragma" content="no-cache"> 
 <meta http-equiv="cache-control" content="no-cache"> 
 <meta http-equiv="expires" content="0">  
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> 
 <meta http-equiv="description" content="This is my page"> 
 <style type="text/css"> 
  select{ 
   width:111px; 
  } 
 </style> 
 </head> 
 
 <body> 
  <select id="provinceID"> 
  <option>選擇省份</option> 
  <option>湖南</option> 
  <option>廣東</option> 
  </select> 
    
  <select id="cityID"> 
   <option>選擇城市</option> 
  </select> 
 </body> 
 <script type="text/javascript"> 
  //創(chuàng)建ajax對(duì)象 
  function createAjax(){ 
   var ajax = null; 
   try{ 
    ajax = new ActiveXObject("microsoft.xmlhttp"); 
   }catch(e){ 
    try{ 
     ajax = new XMLHttpRequest(); 
    }catch(e1){ 
     alert("請(qǐng)更換瀏覽器"); 
    } 
   } 
   return ajax; 
  } 
 </script> 
 
 <script type="text/javascript"> 
  document.getElementById("provinceID").onchange = function(){ 
   //清空城市除了第一項(xiàng) 
   var cityElem = document.getElementById("cityID"); 
   cityElem.options.length = 1; 
    
   //獲取選中的省份 
   var province = this.value; 
   //進(jìn)行編碼處理 
   province = encodeURI(province); 
   if("選擇省份" != province){ 
    var ajax = createAjax(); 
    //提交方式為GET 
    var method = "GET"; 
    //提交路徑為servlet路徑 
    var url = "${pageContext.request.contextPath}/ProvinceServlet?time=" + new Date().getTime()+ 
      "&province=" +province; 
    //準(zhǔn)備發(fā)送異步請(qǐng)求 
    ajax.open(method, url); 
    //由于是get請(qǐng)求,所以不需要設(shè)置請(qǐng)求頭 
    //發(fā)送請(qǐng)求 
    ajax.send(null); 
     
    //監(jiān)聽服務(wù)器響應(yīng)狀態(tài)的變化 
    ajax.onreadystatechange = function(){ 
     //響應(yīng)狀態(tài)為4 表示ajax已經(jīng)完全接受到服務(wù)器的數(shù)據(jù)了 
     if(ajax.readyState == 4){ 
      //接收到的數(shù)據(jù)正常 
      if(ajax.status == 200){ 
       //獲取服務(wù)器傳來的html數(shù)據(jù) 
       var xmlDocument = ajax.responseXML; 
       //進(jìn)行dom操作解析xml 
       //解析xml數(shù)據(jù) 
       var citys = xmlDocument.getElementsByTagName("city"); 
       for(var i = 0; i< citys.length;i++){ 
        //獲取xml中的值 :不能用innerHTML,要用nodeValue 
        var city = citys[i].firstChild.nodeValue; 
        //創(chuàng)建option 
        var optElement = document.createElement("option"); 
        optElement.innerHTML = city; 
        //獲取city 
        var cityElems = document.getElementById("cityID"); 
        cityElems.appendChild(optElement); 
       } 
        
      } 
     } 
    } 
   } 
    
  } 
   
   
 </script> 
</html> 

然后在后臺(tái)ProvinceServlet中通過GET方式獲取請(qǐng)求,將返回的數(shù)據(jù)以O(shè)(輸出)流的方式發(fā)送出去,上面代碼的ajax.responseXML獲取輸出的數(shù)據(jù),并進(jìn)行dom操作

public class ProvinceServlet extends HttpServlet { 
 @Override 
 protected void doGet(HttpServletRequest req, HttpServletResponse resp) 
   throws ServletException, IOException { 
  req.setCharacterEncoding("utf-8"); 
  resp.setCharacterEncoding("utf-8"); 
  String province = req.getParameter("province"); 
  //重新編碼 
  province = new String(province.getBytes("ISO-8859-1"),"utf-8"); 
  //設(shè)置格式為xml 
  resp.setContentType("text/xml;charset=utf-8"); 
  //獲取字符輸出流 
  PrintWriter pw = resp.getWriter(); 
  //拼接xml頭 
  pw.write("<?xml version='1.0' encoding='UTF-8'?>"); 
  pw.write("<citys>"); 
  if ("湖南".equals(province)) { 
   pw.write("<city>長沙</city>"); 
   pw.write("<city>株洲</city>"); 
   pw.write("<city>湘潭</city>"); 
   pw.write("<city>岳陽</city>"); 
  }else if("廣東".equals(province)){ 
   pw.write("<city>廣州</city>"); 
   pw.write("<city>深圳</city>"); 
   pw.write("<city>中山</city>"); 
  } 
  pw.write("</citys>"); 
  pw.flush(); 
  pw.close(); 
 } 
} 

運(yùn)行結(jié)果如下:

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于JavaScript實(shí)現(xiàn)交互式博客

    基于JavaScript實(shí)現(xiàn)交互式博客

    在Web開發(fā)中,JavaScript(JS)是一種至關(guān)重要的編程語言,它使網(wǎng)頁具有交互性,本文主要介紹了如何使用JavaScript實(shí)現(xiàn)一個(gè)交互式博客,需要的可以了解下
    2024-01-01
  • 如何使用Javascript獲取距今n天前的日期

    如何使用Javascript獲取距今n天前的日期

    本篇文章是對(duì)使用Javascript獲取距今n天前日期的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-07-07
  • 與iframe進(jìn)行跨域交互的解決方案(推薦)

    與iframe進(jìn)行跨域交互的解決方案(推薦)

    這篇文章主要介紹了與iframe進(jìn)行跨域交互的解決方案,本文通過實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 淺談JavaScript 中的延遲加載屬性模式

    淺談JavaScript 中的延遲加載屬性模式

    改善性能的最好方法之一是避免重復(fù)兩次相同的工作。因此,只要可以緩存結(jié)果供以后使用,就可以加快程序的速度。延遲加載屬性模式技術(shù)使任何屬性都可以成為緩存層以提高性能。這里說到的延遲加載屬性模式就是利用的訪問器屬性,將計(jì)算昂貴的操作推遲到需要時(shí)再使用
    2021-06-06
  • 原生JS實(shí)現(xiàn)鼠標(biāo)滑動(dòng)撒愛心特效

    原生JS實(shí)現(xiàn)鼠標(biāo)滑動(dòng)撒愛心特效

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)鼠標(biāo)滑動(dòng)撒愛心特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 淺談利用JavaScript進(jìn)行的DDoS攻擊原理與防御

    淺談利用JavaScript進(jìn)行的DDoS攻擊原理與防御

    這篇文章主要介紹了淺談利用JavaScript進(jìn)行的DDoS攻擊原理與防御,以及介紹了相關(guān)的中間人攻擊原理,需要的朋友可以參考下
    2015-06-06
  • 第四章之BootStrap表單與圖片

    第四章之BootStrap表單與圖片

    Bootstrap,來自 Twitter,是目前最受歡迎的前端框架。本文給大家介紹Bootstrap表單與圖片的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • JavaScript Math.round() 方法

    JavaScript Math.round() 方法

    math.round()方法將對(duì)參數(shù)進(jìn)行四舍五入操作,對(duì)js math.round相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • js實(shí)現(xiàn)日期級(jí)聯(lián)效果

    js實(shí)現(xiàn)日期級(jí)聯(lián)效果

    本篇文章主要是對(duì)js實(shí)現(xiàn)日期級(jí)聯(lián)效果的實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-01-01
  • javascript中強(qiáng)制執(zhí)行toString()具體實(shí)現(xiàn)

    javascript中強(qiáng)制執(zhí)行toString()具體實(shí)現(xiàn)

    Javascript通常會(huì)根據(jù)方法或運(yùn)算符的需要而自動(dòng)把值轉(zhuǎn)成所需的類型,這可能導(dǎo)致各種錯(cuò)誤,接下來為大家介紹下javascript如何強(qiáng)制執(zhí)行toString(),感興趣的朋友可以參考下哈
    2013-04-04

最新評(píng)論