客户端控件的特点决定了,每次刷新页面的操作,如选择服务器端的下拉列表框,其值都不会保存。这是由http的无状态性决定的。若想每次刷新页面后客户端控件,如password的值依然存在,则需要借鉴asp.net服务器控件的机制了。
可以在页面添加一个隐藏控件,当用户操作下俩列表时,在后台的c#代码中,将password控件的值付给隐藏控件,最后再将隐藏控件的值付给password控件
但是这里有一个问题就是,我们 无法直接通过c#代码将值付给password控件(虽然已经为此控件添加了runat="server")。经过测试发现使用js可以为password赋值,所以结合两种方式,通过c#代码象客户端注册js脚本,这样就完成了需求。
具体代码如下,客户端代码
<script type="text/javascript">
function test(a) {
document.getElementById("txtpwd").value = a;
}
<div>
<asp:DropDownList ID="DropDownList1" runat="server" AutoPostBack="True" Height="21px" Width="129px" OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged">
<asp:ListItem>河北</asp:ListItem>
<asp:ListItem>河南</asp:ListItem>
<asp:ListItem>山西</asp:ListItem>
</asp:DropDownList>
<input type="password" id="txtpwd" runat="server" />
</div>
<asp:HiddenField ID="HiddenField1" runat="server" />
后台c#代码
this.HiddenField1.Value = this.txtpwd.Value;
ClientScript.RegisterStartupScript(this.GetType(), "", "<script type='text/javascript'>test('"+this.HiddenField1.Value+"');</script>");
上面代码的逻辑如下首先在客户端声明一个名称为test的函数,此函数接受一个参数,并将才参数赋给password控件;在后台的c#代码中首先将password的值获取并赋给隐藏控件,最后象客户端注册一段脚本,此脚本的意思为,执行客户端的test函数,并将隐藏控件的值作为参数传递给次函数