zoukankan      html  css  js  c++  java
  • Response.Write和ClientScript.RegisterStartupScript区别(转载)

    Response.Write的生成HTML代码,你会发现Response.Write方法生成的代码是写到了HTML代码的最开始,即标签之前。此时,所有的 HTML对象都还没有生成,如果要想使用HTML内的对象,并与之交互,就会出现“找不到对象”的错误。因此,笔者推荐一个更加符合CodeBehind方式的方式----使用RegisterXXX方法。RegisterXXX包括:RegisterClientScriptBlock、RegisterStartupScript以及用于判断的IsStartupScriptRegistered函数。

    RegisterStartupScript 的原型是:

      Overridable Public Sub RegisterStartupScript( _
      ByVal key As String, _
      ByVal script As String _
      )
      其中:key表示这个脚本的唯一标识,script是代表脚本的字符串。

      RegisterClientScriptBlock的原型与RegisterStartupScript相同,两个函数不同在于将其包含的脚本代码写入到HTML文件的不同位置。RegisterClientScriptBlock在 Page 对象的元素的开始标记后立即发出客户端脚本,RegisterStartupScript则是在Page 对象的元素的结束标记之前发出该脚本。如果你的脚本有与页面对象(doucument对象)进行交互的语句,则推荐使用RegisterStartupScript,反之如果要想客户端脚本尽可能早的执行,则可以使用RegisterClientScriptBlock或Response.Write。

       如:

    ClientScript.RegisterStartupScript(GetType(), "", "<script>if(confirm('你确认要删除导航:\"" + GridView1.Rows[index].Cells[2].Text + "\"吗?')==true) window.open('del.aspx?id="+ID+"');</script>")

      为了防止在页面中反复加入脚本,在注册脚本时ReisterStartupScript/RegisterClientScriptBlock使用了key作为注册的Key,然后在程序中可以使用IsClientScriptBlockRegistered作判断。

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/haoliumeihua/archive/2009/04/15/4075251.aspx

  • 相关阅读:
    vscode安装扩展插件提示:扩展不可用,XHR error?
    react函数组件的条件渲染和列表渲染
    动态设置背景图片和图片地址
    computed和watch,getters的计算变化
    VueLazyLoad图片懒加载
    vuex实现数据持久化
    vuex不需要一个个引入模块文件
    react的state和setState
    热爱生命 汪国真
    分分钟手写http server
  • 原文地址:https://www.cnblogs.com/zhwl/p/1989252.html
Copyright © 2011-2022 走看看