• asp注意点


      1:ASP中Request对象获取客户端数据的顺序

      

    strMessage = Request("msg")
    strMessage = Request.Form("msg")
    而且,我也看过好多人写的代码,一律都是Request("")的写法,当然这样的写法并没有什么错。
    只是大家应该注意
    Request对象有几个集合来获取客户端提交的数据,一般常用的是QueryString,Form和ServerVariables。
    而不管对于哪种集合其实都是可以通过Request("")这样直接取得的,这里就有一个问题,如果
    Get方式和Post方式提交了同样的一个变量,比如username=cqq,那么你用Request("username")
    取出来的到底是Get过来的数据还是Post过来的数据呢?
    所以,问题到了这里,大家就应该想到了, Request从这几个集合取数据是有顺序的,从前到后
    的顺序依次是 QueryString,Form,最后是ServerVariables。Request对象按照这样的顺序依次搜索
    这几个集合中的变量,如果有符合的就中止,后面的就不管了。 所以上面的例子Request("username")
    取到的实际是Get方法提交的数据。
    所以为了提高效率,减少无谓的搜索时间,同时也是为了程序的规范,建议大家还是用Request.集合的
    方式更好一点,比如Request.Form("username")。
    下面是一个测试例子,提交以后,大家可以直接在地址后面加上 ?username=aaa 来测试:
    <%
    If request("submit")<>"" then
    Response.Write "直接取:"& Request("username") & "<br>"
    Response.Write "取Get:" & Request.QueryString("username") & "<br>"
    Response.Write "取Post:" & Request.Form("username") & "<br>"
    End if
    %>
    <form name=form1 action="" method=post>
    <input type=test name="username" value="postuser">
    <input type=submit name="submit" value="test">
    </form>

    详细出处参考:http://www.jb51.net/article/657.htm

      2:获取客户端的当前网址及上次访问网址

      

      3:论 RESPONSE.WRITE和<%=%>

      RESPONSE.WRITE与<%=%>都是ASP程序向客户端输出字符串的方法,虽然两者的结果相同但是其效果是不同的。
    一般的来说我们大部分时间将<%=%>用于HTML与ASP代码相混合的状态下,而Response.Write用于〈%……%〉脚本段中,但从VBScript 语法 <% = expression %> 将“表达式”的值写入 ASP 输出流来分析这个方法可以发现。如果响应缓冲没有打开,则这些语句的每一句都会导致通过网络,以许多小型包的形式,向浏览器写入数据。这是非常慢的。另外,解释少量脚本和 HTML,将导致在脚本引擎和 HTML 之间切换,也降低了性能。因此,对于 Response.Write 的一个调用,替换内嵌的密集组合表达式在应用程序的性能上可以得到很大的提高,一般的来讲我们通常使用以下语句显示数据库内容
    [code]
    <% do while not rs.eof %>
    <%= rs("flides") %>
    <% rs.movenext %>
    <% loop %>
    [/code]
    将不如
    [code]
    <% OUT_str=""
    for i = 1 to rs.recodecount
    OUT_str=OUT_str+rs("flides")
    rs.movenext
    next
    Response.Write( OUT_str)
    %>
    [/code]
    执行速度快。
    另外:例子中的
    for i = 1 to rs.recodecount
    替换掉
    do while not rs.eof
    也是一则技巧,其有用之处在于避免了在每个循环中检测rs.eof的数值而用记数循环,效率可以进一步提高

      
  • 相关阅读:
    写了一个数据库的连继ID号(格式:xxxx000001)
    热心的网友<寒羽枫>帮忙解决水晶报表打印纸张问题
    解决vs2005自带水晶报表次数的限制的次数
    WebWork教程 Interceptor(拦截器)
    由于最近网站内容需要更新的还是满多的,于是想开发一个采集系统。收集了一下资料。
    ASP.NET AJAX 1.0 Beta 2 发布
    水晶报表的显示与打印不一至问题
    去年治疗过敏性鼻炎所用的药。
    正则表达式快速入门教程
    sql复制一条相同的记录最快最好的办法。
  • 原文地址:https://www.cnblogs.com/pricks/p/1682752.html
Copyright © 2020-2023  润新知