jquery ajax呼び出しから取り込まれたasp.netドロップダウンリストコントロールから選択したアイテムを取得しようとしています。画面上の項目をループして、ページのソースに添付されているオプションを確認できますが、C# バックエンド コードから値を取得しようとすると、空白の値が取得されます。これは私が持っているものです:
$('#<%=Button2.ClientID %>').click(function () {
var Dropdown2 = $('#<%=ddlListAgents.ClientID %>');
Dropdown2.empty();
$.ajax({
type: "POST",
url: "WebForm3.aspx/fetchData",
data: "{selectedAgent: '" + $('#<%=txtAgentNameText.ClientID %>').val() +"'}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (response) {
Dropdown2.append(new Option("--Select Agent --", 0));
$.each(response.d, function (index, item) {
Dropdown2.append(new Option(item.Name, item.ID));
});
},
error: function (xhr, ajaxOptions, thrownError) {
alert(xhr.status);
alert(thrownError);
}
});
});
その呼び出しの後、すべてが正常に設定され、オプションを参照できます。しかし、ボタンをクリックして、このコード(テストコード)で選択した値を取得しようとすると:
protected void btnSelectAgentAdd_ServerClick(object sender, EventArgs e)
{
foreach (ListItem item in ddlListAgents.Items)
{
if (item.Selected.Equals(true))
{
item.Value.ToString();
}
else
{
item.Value.ToString();
}
}
string one = ddlListAgents.SelectedValue;
}
最初のループの後、コードは for ループから抜け出し、ddlListAgents.SelectedValue は空の文字列と等しくなります。
これは、データセットを取得するために使用している方法です。
[WebMethod]
public static List<AgentName> fetchData(string selectedAgent)
{
Dictionary<string, string> list = new Dictionary<string, string>();
BL.Client client = new BL.Client();
var agents = new List<AgentName>();
if (selectedAgent != string.Empty)
{
list = client.GetAgentNamesForPopupSearch(selectedAgent);
}
foreach (KeyValuePair<string, string> val in list)
{
agents.Add(new AgentName { ID = Convert.ToInt32(val.Key), Name = val.Value });
}
return agents;
}
どんなアドバイスも大歓迎です。前もって感謝します、 ラツィアーレ
編集:ページ読み込みイベントが追加されました:
if (!IsPostBack)
{
Dictionary<string, string> list = new Dictionary<string, string>();
BL.Client client = new BL.Client();
list = client.GetAgentNamesForPolicies2(Convert.ToInt32(4));
ddlAgentName.DataSource = list;
ddlAgentName.DataTextField = "Value";
ddlAgentName.DataValueField = "Key";
ddlAgentName.DataBind();
ddlAgentName.Items.Insert(0, new ListItem("-- Select Agent --", string.Empty));
}