この問題は私を悩ませてきました。なぜこれが役立つのかについての説明は役に立ちます。
次の DOM があるとします。
<body>
<form id="form1" runat="server">
<div id="myDiv" runat="server" data-type="Monkey">
Choose your inner animal!
<ul>
<li class="selected">Monkey</li>
<li>Tiger</li>
<li>Dog</li>
<li>Bunny</li>
</ul>
</div>
<asp:Button runat="server" ID="btnSubmit" Text="Submit" />
</form>
</body>
<script src="Assets/js/jquery-1.9.0.min.js" type="text/javascript"></script>
<script>
$(document).ready(function () {
$('li').bind('click', function () {
$('li.selected').removeClass('selected');
var animal = $(this).addClass('selected').text();
//$('#myDiv').data('type', animal);
$('#myDiv').attr('data-type', animal);
});
});
</script>
コードビハインド:
Partial Class _Default
Inherits System.Web.UI.Page
Protected Sub btnSubmit_Click(sender As Object, e As System.EventArgs) Handles btnSubmit.Click
Dim type As String = myDiv.Attributes("data-type")
MsgBox(type)
End Sub
End Class
MsgBoxは常にデフォルト値の「Monkey」で返されます。ここで、非表示フィールドに値を保存し、ボタンのクリック時に値を呼び出すという回避策を実装しましたが、それは機能します。更新パネルを試してみましたが、うまくいきませんでしたが、更新パネルが嫌いで、とにかく使用したことがないので、それは問題ではありません。