JavaScriptを使用してオプションが追加されたときに、コードドロップでDropDownListのSelectedValueを読み取るにはどうすればよいですか?JavaScriptを使用してオプションが追加されたときに、コードドロップでDropDownListのSelectedValueを読み取るにはどうすればよいですか?
もう少し背景:私はドロップダウンリストを持っており、JavaScriptを使って値を入力したいので、ユーザーが最初のドロップダウンリストで選択を変更したときにポストバックを避けるようにします。
私は更新パネルを使用できません。
シンプルなデモで問題を実演しています。ここに私のマークアップコードは次のとおりです。
<p>
<asp:DropDownList runat="server" ID="FilterDropDownList" />
</p>
<p>
<asp:Button runat="server" ID="SearchButton" Text="Search"
onclick="SearchButton_Click" /><br/>
<asp:TextBox runat="server" ID="QueryTextBox" />
</p>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.0/jquery.min.js"></script>
<script type="text/javascript">
$(function() {
var filterDropDownListId = '#<%= FilterDropDownList.ClientID %>';
$(filterDropDownListId).append($('<option>').prop('value', 'Alpha').html('A'));
$(filterDropDownListId).append($('<option>').prop('value', 'Beta').html('B'));
});
</script>
そして、私は、次のしている背後にあるコードで:
protected override void Render(HtmlTextWriter writer)
{
// Register the allowed values for the down down list.
Page.ClientScript.RegisterForEventValidation(FilterDropDownList.UniqueID, "Alpha");
Page.ClientScript.RegisterForEventValidation(FilterDropDownList.UniqueID, "Beta");
base.Render(writer);
}
protected void SearchButton_Click(object sender, EventArgs e)
{
Response.Redirect(
String.Format("{0}?dropdown={1}&query={2}",
Request.Url.AbsolutePath,
FilterDropDownList.SelectedValue,
QueryTextBox.Text));
}
問題はFilterDropDownList.SelectedValueが空であること、です。私はそれが "アルファ"か "ベータ"のどちらかであると予想していただろう。私は問題なくQueryTextBox.Textの値を読むことができます。
JavaScriptを使用して値が入力されている場合、MyDropDownList.SelectedValueを読み取ることはできますか?それとも、別のアプローチを使わなければならないのですか?
本当に必要ですか?セキュリティエラーを避けるために、RegisterForEventValidationを使用して可能な値を登録する必要があるので、ちょっと変わったようです。 –
私は100%同意します。だから私はあなたの質問をお気に入りに追加しました。:)私はそれが可能かどうかを見たいと思っています。これがあなたの開発を止めている問題であれば、私の提案を実装することで問題を「回避」することができ、コミュニティから満足のいく答えを得ることになったら、戻って実装することができます。 –
私は数日間未回答の質問を残し、説明を希望します。何も起きなければ、私はあなたに正解のクレジットを与えます。 :) –