关于Ajax的问题,在update pannel里textbox的文本改变事件触发怎么没反应
我在updatepannel里放了两个textbox,在textbox1的文本改变事件里写:textbox2.text=textbox1.text+",";然后,调试,我...
我在update pannel里放了两个textbox,在textbox1的文本改变事件里写:
textbox2.text = textbox1.text + ",";
然后,调试,我在textbox1里输入文本,textbox2没有反应。于是我停止调试,设计页面里我在update pannel外加了一个button,这个button什么也不写,然后重新调试,在textbox1里输入文本,还是没反应,点一下button,结果textbox2有反应了。这说明还是要刷新啊。。
怎样可以用Ajax无刷新实现textbox1的文本一改变textbox2马上就有反应呢?
光标不移到其他地方,只要文本改变了就有反应呢? 展开
textbox2.text = textbox1.text + ",";
然后,调试,我在textbox1里输入文本,textbox2没有反应。于是我停止调试,设计页面里我在update pannel外加了一个button,这个button什么也不写,然后重新调试,在textbox1里输入文本,还是没反应,点一下button,结果textbox2有反应了。这说明还是要刷新啊。。
怎样可以用Ajax无刷新实现textbox1的文本一改变textbox2马上就有反应呢?
光标不移到其他地方,只要文本改变了就有反应呢? 展开
5个回答
展开全部
首先说,你这种客户端的响应时不需要ajax技术的。JavaScript就可以。
其次说,你的设计有问题,textbox1、textbox2不可以放在一个updatepanel里,原因很简单,也是楼主需要切忌的,updatepanel不是不刷新,而是刷新整个updatepanel,只是不刷新整个页面了而已。
如你所给例子,你输入一次文字,textbox2赋值了之后,updatepanel就刷新了,那么textbox2的值就没有了。
事实就是赋值之后被刷新了。。。。所以看不见值。
还是用JavaScript实现吧,因为这种客户端事件完全不需要服务器来干预。
其次说,你的设计有问题,textbox1、textbox2不可以放在一个updatepanel里,原因很简单,也是楼主需要切忌的,updatepanel不是不刷新,而是刷新整个updatepanel,只是不刷新整个页面了而已。
如你所给例子,你输入一次文字,textbox2赋值了之后,updatepanel就刷新了,那么textbox2的值就没有了。
事实就是赋值之后被刷新了。。。。所以看不见值。
还是用JavaScript实现吧,因为这种客户端事件完全不需要服务器来干预。
展开全部
TextBox1 的AutoPostBack属性设为true
UpdatePanel 增加属性 UpdateMode="Conditional"
然后在UpdatePanel标记中添加标记
<Triggers>
<asp:AsyncPostBackTrigger ControlID="TextBox1"textChanged" />
</Triggers>
运行之后
在textbox1中输入值 光标移到别的地方 textbox2即出现textbox1的值
UpdatePanel 增加属性 UpdateMode="Conditional"
然后在UpdatePanel标记中添加标记
<Triggers>
<asp:AsyncPostBackTrigger ControlID="TextBox1"textChanged" />
</Triggers>
运行之后
在textbox1中输入值 光标移到别的地方 textbox2即出现textbox1的值
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一般情况下,控件的AutoPostBack属性默认是fals,需要改成true。
你把2个textbox都放在了这个panel中,那么UpdatePanel的UpdateMode默认是Allways不必更改,就是说所有panel内控件的任何事件都是局部更新,不会整页回送。
如果你把textbox1放在updatepanel外,那么需要UpdateMode="Conditional",
另外添加Triggers,
<Triggers>
<asp:AsyncPostBackTrigger
ControlID="TextBox1"
EventName="TextChanged"
/>
</Triggers>
这就是panel外部控件触发panel更新,注意UpdateMode必须是Conditional,否则添加Triggers是错误的。
ajax,建议看陈黎夫的《ASP.NET Ajax程序设计》第I卷:服务器端,这本书比《征服****》要好的多,另外就是章立民的书。
你把2个textbox都放在了这个panel中,那么UpdatePanel的UpdateMode默认是Allways不必更改,就是说所有panel内控件的任何事件都是局部更新,不会整页回送。
如果你把textbox1放在updatepanel外,那么需要UpdateMode="Conditional",
另外添加Triggers,
<Triggers>
<asp:AsyncPostBackTrigger
ControlID="TextBox1"
EventName="TextChanged"
/>
</Triggers>
这就是panel外部控件触发panel更新,注意UpdateMode必须是Conditional,否则添加Triggers是错误的。
ajax,建议看陈黎夫的《ASP.NET Ajax程序设计》第I卷:服务器端,这本书比《征服****》要好的多,另外就是章立民的书。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
updatepanel是局部刷新的!这就导致了你以为页面没有在刷新!
其实我觉得不用楼上那么麻烦!只要有了更改文本属性后激发的事件(OnTextChanged)再加上一个AutoPostBack="True" 这时候你在cs的OnTextChanged事件里写TextBox2.Text = TextBox1.Text.ToString();当光标移开了 textbox2上面也就自然显示了!
其实我觉得不用楼上那么麻烦!只要有了更改文本属性后激发的事件(OnTextChanged)再加上一个AutoPostBack="True" 这时候你在cs的OnTextChanged事件里写TextBox2.Text = TextBox1.Text.ToString();当光标移开了 textbox2上面也就自然显示了!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在textbox1的属性里加上AutoPostBack="True"
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询