1 . Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", " <script language='javascript' defer>alert('登录成功!'); </script>")
2.
这两天测试网站的时候,发现网站的注册页面的一个bug,实现的功能是当点击"注册"按钮进行注册,后台代码中判断验证码,当用户输入的验证码和生成的验证码不一致时以alert的形式弹出对话框,提示用户验证码错误.但这时,当对话框弹出后,页面中的有些css样式失效.
查找了下原因,发现是生成弹出对话框的代码是这么写的:Response.Write("<script>alert('验证码不正确');</script>");这段代码在执行的时候会在页面的最顶部生成对应的html代码.而由于ASP.NET 2.0默认采用http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd文档类型定义,它就要求在<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">的前面不能有任何输出。
解决办法是:不用Response.Write方法(缺点一是丢失css样式,二是破坏代码的结构).而用ClientScript.RegisterClientScriptBlock方法来实现相应的功能.我的代码:


















调用时,使用如下方式:

这样既不会产生css样式丢失的问题,生成的html代码也不破坏html文件的结构.
引用地址:http://hi.baidu.com/eduing/blog/item/c961a2fb1f6954254e4aea45.html
3. 使用Response.Write("");会把脚输出到页面的第一行,这样就破坏了文档的模型,它的解析就会出现问题。下面的这句必须在页面的第一行才可以。 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
可以再Response.Write("");的字符串的最后加上window.location.href=window.location.href;页面从定向,
引用地址:http://topic.csdn.net/u/20090708/16/8340f6ac-726b-4c58-ad1d-43ee680d20c5.html