2010-04-14 24 views
25

Sto sviluppando uno stato di campagna a cascata elenco a discesa ... Sono tornato JSON risultato in base countryId ma non so come popolare/riempirlo in una nuova casella di riepilogo a discesa ...Come compilare un elenco a discesa con dati json in jquery?

Ecco quello che sono utilizzando,

function getstate(countryId) { 
    $.ajax({ 
     type: "POST", 
     url: "Reg_Form.aspx/Getstates", 
     data: "{'countryId':" + (countryId) + "}", 
     contentType: "application/json; charset=utf-8", 
     global: false, 
     async: false, 
     dataType: "json", 
     success: function(jsonObj) { 
      alert(jsonObj.d); 
     } 
    }); 
    return false; 
} 

e vigile ha dato questo,

{"Table" : [{"stateid" : "2","statename" : "Tamilnadu"}, 
      {"stateid" : "3","statename" : "Karnataka"}, 
      {"stateid" : "4","statename" : "Andaman and Nicobar"}, 
      {"stateid" : "5","statename" : "Andhra Pradesh"}, 
      {"stateid" : "6","statename" : "Arunachal Pradesh"}]} 

E la mia pagina aspx ha questo,

<td> 
<asp:DropDownList ID="DLCountry" runat="server" CssClass="dropDownListSkin" 
onchange="return getstate(this.value);"> 
</asp:DropDownList> 
    </td> 
<td> 
<asp:DropDownList ID="DLState" runat="server" CssClass="dropDownListSkin"> 
    </asp:DropDownList> 
</td> 

Qualsiasi suggerimento su come compilare DLState discesa ...

EDIT:

Quando ho controllato attraverso Firebug ho ricevuto la risposta per il mio ajax inviati,

{"d":"{\"Table\" : [{\"stateid\" : \"2\",\"statename\" : \"Tamilnadu\"},{\"stateid\" : \"3\",\"statename\" : \"Karnataka\"},{\"stateid\" : \"4\",\"statename\" : \"Andaman and Nicobar\"},{\"stateid\" : \"5\",\"statename\" : \"Andhra Pradesh\"},{\"stateid\" : \"6\",\"statename\" : \"Arunachal Pradesh\"},{\"stateid\" : \"7\",\"statename\" : \"Assam\"},{\"stateid\" : \"8\",\"statename\" : \"Bihar\"},{\"stateid\" : \"9\",\"statename\" : \"Dadra and N. Haveli\"},{\"stateid\" : \"10\",\"statename\" : \"Daman and Diu\"},{\"stateid\" : \"11\",\"statename\" : \"Delhi\"},{\"stateid\" : \"12\",\"statename\" : \"Goa\"},{\"stateid\" : \"13\",\"statename\" : \"Gujarat\"},{\"stateid\" : \"14\",\"statename\" : \"Haryana\"},{\"stateid\" : \"15\",\"statename\" : \"Himachal Pradesh\"},{\"stateid\" : \"16\",\"statename\" : \"Jammu and Kashmir\"},{\"stateid\" : \"17\",\"statename\" : \"Kerala\"},{\"stateid\" : \"18\",\"statename\" : \"Laccadive Islands\"},{\"stateid\" : \"19\",\"statename\" : \"Madhya Pradesh\"},{\"stateid\" : \"20\",\"statename\" : \"Maharashtra\"},{\"stateid\" : \"21\",\"statename\" : \"Manipur\"},{\"stateid\" : \"22\",\"statename\" : \"Meghalaya\"},{\"stateid\" : \"23\",\"statename\" : \"Mizoram\"},{\"stateid\" : \"24\",\"statename\" : \"Nagaland\"},{\"stateid\" : \"25\",\"statename\" : \"Orissa\"},{\"stateid\" : \"26\",\"statename\" : \"Pondicherry\"},{\"stateid\" : \"27\",\"statename\" : \"Punjab\"},{\"stateid\" : \"28\",\"statename\" : \"Rajasthan\"},{\"stateid\" : \"29\",\"statename\" : \"Sikkim\"},{\"stateid\" : \"30\",\"statename\" : \"Tripura\"},{\"stateid\" : \"31\",\"statename\" : \"Uttar Pradesh\"},{\"stateid\" : \"32\",\"statename\" : \"West Bengal\"}]}"} 
+0

Vedere la mia risposta su questo per un esempio: http://stackoverflow.com/questions/2403441/jquery-ajax- pass-success-data-into-separate-function/2403573 # 2403573 –

+0

L'utilizzo dell'evento onchange per un elenco a discesa (o html select) non ha funzionato per me in Firefox e Chrome. Ho usato jQuerys change() invece (http://api.jquery.com/change/). –

+0

@Daniel '$ (" # <% = DLState.ClientID%> "). Html (listItems);' questa riga sembra avere un errore ... Qualsiasi suiggestion .. –

risposta

49
var listItems= ""; 
var jsonData = jsonObj.d; 
    for (var i = 0; i < jsonData.Table.length; i++){ 
     listItems+= "<option value='" + jsonData.Table[i].stateid + "'>" + jsonData.Table[i].statename + "</option>"; 
    } 
    $("#<%=DLState.ClientID%>").html(listItems); 

Esempio

<html> 
    <head></head> 
    <body> 
     <select id="DLState"> 
     </select> 
    </body> 
    </html> 

    /*javascript*/ 
    var jsonList = {"Table" : [{"stateid" : "2","statename" : "Tamilnadu"}, 
       {"stateid" : "3","statename" : "Karnataka"}, 
       {"stateid" : "4","statename" : "Andaman and Nicobar"}, 
       {"stateid" : "5","statename" : "Andhra Pradesh"}, 
       {"stateid" : "6","statename" : "Arunachal Pradesh"}]} 

    $(document).ready(function(){ 
     var listItems= ""; 
     for (var i = 0; i < jsonList.Table.length; i++){ 
     listItems+= "<option value='" + jsonList.Table[i].stateid + "'>" + jsonList.Table[i].statename + "</option>"; 
     } 
     $("#DLState").html(listItems); 
    });  
+0

@jon jsonObj.Table non è definito? Perché ho capito? –

+0

@Pandiya Chendur, non sono sicuro, lasciatemi pubblicare un esempio funzionante e forse questo mi aiuterà. Prova jsonObj.d.Table – Jon

+0

@jon ok grazie per la risposta ... –

5
//javascript 
//teams.Table does not exist 

function OnSuccessJSON(data, status) { 
    var teams = eval('(' + data.d + ')'); 
    var listItems = ""; 
    for (var i = 0; i < teams.length; i++) { 
     listItems += "<option value='" + teams[i][0]+ "'>" + teams[i][1] + "</option>"; 
    } 
    $("#<%=ddlTeams.ClientID%>").html(listItems); 
} 
0

provare questo il suo ha lavorato per me

$(document).ready(function(e){ 
 
     $.ajax({ 
 
      url:"fetch", 
 
      processData: false, 
 
      dataType:"json", 
 
      type: 'POST', 
 
      cache: false, 
 
      success: function (data, textStatus, jqXHR) { 
 
         
 
         $.each(data.Table,function(i,tweet){ 
 
\t \t \t $("#list").append('<option value="'+tweet.actor_id+'">'+tweet.first_name+'</option>'); 
 
\t \t \t });} 
 
     }); 
 
    });

+0

prova questo funzionerà –

+0

è solo un esempio di come leggere json e implementarlo –

Problemi correlati