Response.Write 與 Page.ClientScript.RegisterStartupScript 與 Page.ClientScript.RegisterClientScriptBlock 之間的區別
方法1,使用Response.Write,這種方法會把JS代碼寫在頁面的最頂部(<html>的前面):System.Web.HttpContext.Current.Response.Write("<script language=Javascript>alert('JS代碼');</script>");
方法2,使用RegisterStartupScript,這種方法會把JS代碼嵌入在頁面的底部、表單的最后 (</form>前面),適用于要在頁面控件加載完成后運行的JS代碼 :System.Web.UI.Page page = (System.Web.UI.Page)System.Web.HttpContext.Current.Handler;if (!page.ClientScript.IsStartupScriptRegistered(page.GetType(),"clientScript")) page.ClientScript.RegisterStartupScript(page.GetType(), "clientScript", "<script language=javascript>alert('JS代碼');</script>");
方法3,使用RegisterClientScriptBlock,這種方法會把JS代碼嵌入在頁面的頂部、表單的最前 (<form>后面),適用于要在控件加載前執行的JS代碼,類似于上面的Response.Write方式 :System.Web.UI.Page page = (System.Web.UI.Page)System.Web.HttpContext.Current.Handler;if (!page.ClientScript.IsClientScriptBlockRegistered(page.GetType(),"clientScript")) page.ClientScript.RegisterClientScriptBlock(page.GetType(), "clientScript", "<script language=javascript>alert('JS代碼');</script>");
那么,方法2和方法3之間有何不同呢?主要區別在于,RegisterStartupScript方法是將 JavaScript 嵌入到 ASP.NET 頁面的底部,恰好位于關閉元素</form>的前面。RegisterClientScriptBlock方法是將 JavaScript 嵌入到頁面中開啟元素<form>的緊后面。那么,這有何不同呢?正如我們將要看到的,這有很大的不同。
就此列舉一例,以下是在頁面加載到瀏覽器時,將焦點置于該頁面上的一個文本框中的方法 - 使用利用了RegisterStartupScript方法的 Visual Basic:
<span style="color: rgb(255, 0, 0);">Page.ClientScript.RegisterStartupScript(Me.GetType(), "Testing", _ "document.forms[0]['TextBox1'].focus();", True)</span>
由于在瀏覽器運行到頁面底部并執行此小段 JavaScript 時,就已生成了頁面上的文本框,并已將其放到了頁面中,因此,此方法運行正常。但是,如果不按照上述方法,而編寫如下代碼(使用RegisterClientScriptBlock方法):
<span style="color: rgb(255, 0, 0);">Page.ClientScript.RegisterClientScriptBlock(Me.GetType(), "Testing", _ "document.forms[0]['TextBox1'].focus();", True)</span>
文本框控件將不會獲得焦點,且會在頁面上生成一個 JavaScript 錯誤 。
新聞熱點
疑難解答