bs开发常见问题集锦
TextBox客户端JS赋值 后台获取
textbox的内容总是无法获得
ReadOnly
获取或设置一个值,用于指示能否更改 TextBox 控件的内容。
重要事项:
发生回发时,TextBox 控件(其 ReadOnly 属性设置为 true)的 Text 值被发送到服务器,但是服务器不处理只读文本框。这样可以防止恶意用户更改只读的 Text 值。在回发之间,Text 属性的值保留在视图状态中,除非经过服务器端代码修改。
要想不让客户端更改,又想获得的话,可以用两种方法:
1、使用input的text控件代替;
2、不要直接使用属性设置readonly,而是通过在代码中用Attributes["readonly"] = "true"来设置。
3、TextBox1.Attributes["contentEditable"] = "false";
等效于ReadOnly="true"或直接从前台设置TextBox的属性contentEditable="false"
解决:在Page_Load中设置
TextBox1.Attributes["contentEditable"] = "false";//等效于ReadOnly="true"或直接从前台设置TextBox的属性contentEditable="false"
解决办法:
因为JS给TEXTBOX赋值,.net不会保存TEXTBOX的状态,所以有时候就会丢掉TEXTBOX的值,因此要在后台取值正确的方法是使用 Request.Form["TEXTBOXID"] 就可以了。
SQL="select * from 表名 where 时间/日期字段 between '"& 传递过来开始的时间值 &"' and '"& DateAdd("d",1,""&request.Form("endtime")&"")&"'"
Access数据库:
SQL="select * from 表名 where Ap_addtime between #"& 传递过来开始的时间值 &"# and #"&DateAdd("d",1,""&request.Form("endtime")&"")&"# ..."
access数据库的日期间用#日期#隔开,mssql用'单引号',
... sgTime between #2012-03-10# and #2012-03-21# ...
sql="select * from 表名 where 时间/日期字段 between #"& 开始的时间 &"# and #"& 结束的时间 &"#"