成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

ASP.NET中JavaScript插入的方法淺析

開發 后端
ASP.NET中插入JavaScript的方法有哪些呢?他們是如何實現的呢?那么本文就向你介紹這些方法并簡單介紹他們。

一、ASP.NET中JavaScript插入的意義:

.Net是微軟公司下一代的戰略核心,ASP.NET是.NET戰略在Web開發方面的具體實現。它繼承了ASP的簡單性和易用性,同時克服了ASP程序結構化較差,難于閱讀和理解的缺點。特別是服務器端控件和事件驅動模式的引入,使得Web應用程序的開發更接近于過去桌面程序的開發。

在各種各樣介紹ASP.NET的文章和書籍中,都把重點放在了服務器控件和.Net Framework SDK上,因為這是ASP.NET中最新和最具革命性的改進;與此相反,在過去的Web開發中占據重要地位的客戶端腳本JavaScript(也包括VBScript)則鮮有提及,似乎有了服務器端程序,已經不需要客戶端腳本了。但是,服務器端的程序畢竟需要一次瀏覽器與Web服務器的交互,對于ASP.NET來說,就是一次頁面的提交,需要來回傳送大量的數據,而很多工作,比如輸入驗證或者刪除確認等,完全可以用JavaScript來實現。因此,探討在ASP.NET中如何使用JavaScript仍然很有必要。

二、ASP.NET中JavaScript插入的應用示例

1.為頁面上的某個服務器控件添加JavaScript事件

服務器控件最終生成的仍然是普通的HTML,比如﹤asp:textbox﹥生成input text。表單中的每個HTML控件都有它自己的JavaScript事件,比如Textbox有onchange事件,Button有onclick事件,Listbox有onchange事件等。要想為服務器控件添加客戶端的事件,需要用到Attributes屬性。Attributes屬性是所有的服務器控件都有的一個屬性,它用來為最終生成的HTML添加自定義的一些標記。假設Web Form上有一個保存按鈕btnSave,希望在用戶點此按鈕時提示用戶是否確實要保存(比如一旦保存就無法恢復等),則應在Page_Load事件中添加如下代碼:

  1. if not page.isPostBack() then  
  2.  
  3. btnSave.Attributes.Add(“onclick”,”Javascript:return confirm(‘Are you sure to save?’);”)  
  4.  
  5. end if 

要注意的是‘return’,這是不可省的,否則即使用戶點了取消,數據仍然會保存。

2.為Datagrid中的每一行添加Javascript事件

假設Datagrid的每一行有一個刪除按鈕,希望在用戶點此按鈕時提示用戶是否確實要刪除此條記錄,以防用戶點錯了行,或僅僅是無意中點了刪除按鈕。

無論這個刪除按鈕是什么名字,都不能象上個例子那樣直接引用,因為每一行都有這樣一個按鈕,它們是Datagrid中的子控件。在這種情況下,需要用到Datagrid的OnItemDataBound事件。OnItemDataBound事件發生在Datagrid的每一行數據綁定到Datagrid之后(即一行激發一次)。首先在Datagrid的聲明中添加如下代碼:

  1. ﹤asp:datagrid id="grd1" runat="server" OnItemDataBound = "ItemDataBound" ﹥  
  2.  
  3. …Columns definition here  
  4.  
  5. ﹤/asp:datagrid﹥  

此處說明OnItemDataBound事件發生時調用ItemDataBound方法,在代碼后置文件中添加此方法的定義:

  1. Sub ItemDataBound(ByVal sender As Object, ByVal e As DataGridItemEventArgs)  
  2.  
  3. If e.Item.ItemType ﹤﹥ ListItemType.Header And e.Item.ItemType ﹤﹥ ListItemType.Footer Then  
  4.  
  5. Dim oDeleteButton As LinkButton = e.Item.Cells(5).Controls(0)  
  6.  
  7. oDeleteButton.Attributes("onclick") = "javascript:return Confirm ('Are you sure you want to delete" & DataBinder.Eval(e.Item.DataItem, "m_sName") & "?')" 
  8.  
  9. End If  
  10.  
  11. End Sub 

由于Datagrid的標題行和腳注行也會激發此事件,所以首先判斷激發此事件的行不是標題行和腳注行。這里假設Delete按鈕位于Datagrid的第6列(第一列是0),且Datagrid的Datasource中包含名為”m_sName”的列

3.引用編輯狀態下的Datagrid中的控件

Datagrid的內置編輯功能使得當記錄的字段較少時的一種編輯方法。用戶不必進入一個單獨的頁面編輯記錄,而是直接點編輯按鈕就可以使當前行進入編輯模式。而另一方面,有一些Javascript程序需要引用控件的名稱。比如,很多程序在需要用戶輸入日期時都提供一個日期控件以保證日期格式的合法性,當用戶點控件圖標時彈出一個新窗口供用戶選擇日期。此時需要把顯示日期的文本框的ID提供給新窗口,以便當用戶選擇日期后值可以回填到文本框中。

如果是普通的服務器文本框控件,它的ID與生成的HTML輸入框的ID是相同的;但是在Datagrid的編輯狀態下,兩個ID并不相同(其道理與上例相同),這就需要用到控件的ClientID屬性。

  1. Protected Sub ItemEdit(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs)  
  2.  
  3. Dim sDateCtrl as string  
  4.  
  5. sDateCtrl = grd1. Items (e.Item.ItemIndex) . Cells(2). FindControl("txtDate") . ClientID  
  6.  
  7. End Sub 

這里假設ItemEdit方法是Dategrid的OnItemEdit事件處理程序,同時在Datagrid的第三列包含一個名為txtDate的服務器文本框控件。

4.引用ASP.Net自動生成的Javascript程序

所謂的“服務器端控件”是針對開發人員的,在生成的HTML源程序中并沒有服務器和客戶端之分,都是標準的HTML,DHTML和Javascript。它之所以能響應用戶的輸入是因為每個控件的事件處理程序最終都生成了一段腳本,此腳本重新提交頁面使得Web Server有機會再次響應并作出處理。通常情況下我們不必知道此腳本是什么也不必直接調用此腳本,但在有些情況下,適當地調用此腳本可以簡化許多工作。請看下面兩個例子。

● 點Datagrid的任一位置以選中一行

Datagrid提供了一種內置的選擇按鈕,當點此按鈕時選中當前行(可以設置SelectedItemStyle屬性以使當前行有不同的外觀)。但用戶可能更習慣于點任意一個位置都能選中一行,如果完全自己實現這個功能相當煩瑣。一個好的思路是添加一個選擇按鈕,但使此列隱藏,當點任一行時調用此按鈕產生的Javascript腳本。

  1. Sub Item_Bound(ByVal sender As Object, ByVal e As DataGridItemEventArgs )  
  2.  
  3. Dim itemType As ListItemType  
  4.  
  5. itemType = CType(e.Item.ItemType, ListItemType)  
  6.  
  7. If (itemType ﹤﹥ ListItemType.Header) And _  
  8.  
  9. (itemType ﹤﹥ ListItemType.Footer) And _  
  10.  
  11. (itemType ﹤﹥ ListItemType.Separator) Then  
  12.  
  13. Dim oSelect As LinkButton = CType(e.Item.Cells(5).Controls(0), LinkButton)  
  14.  
  15. e.Item.Attributes("onclick") = Page. GetPostBackClientHyperlink (oSelect, "")  
  16.  
  17. End Sub 

這里假設選擇按鈕位于第6列。e.Item代表了一行,從生成的HTML上看就是在每個﹤tr﹥里增加了一個onclick事件。Page.GetPostBackClientHyperLink方法返回頁面中LinkButton控件產生的客戶端腳本,其中第一個參數是Linkbutton控件,第二個參數是傳遞給此控件的參數,通常為空。如果不是LinkButton控件,有一個類似的函數GetPostBackClientEvent,讀者可以參考MSDN。

● 服務器產生的腳本與手工添加的腳本沖突

服務器控件的服務器事件一般對應到客戶端控件的相應事件,如Dropdownlist的SelectedIndexChanged事件對應HTML ﹤Select﹥的onchange事件。如果你要手工增加一個onchange事件,則會在客戶端產生兩個onchange,瀏覽器就會忽略掉一個。比如用戶希望每當改變了Dropdownlist中的選項就保存到數據庫(雖然不是很常見,但確實有這種需要),但同時還希望提醒用戶是否確實要做保存。顯然,保存的代碼應該放在SelectedIndexChanged事件中,而提醒的工作應該手工加一段onchange事件。結果就是兩個onchange只能執行一個。正確的方法應該是添加一個不可見的保存按鈕,在手工增加的onchange事件中調用此按鈕生成的程序。

Page_Load方法如下:

  1. Dim sCmd as string   
  2.  
  3. sCmd=Page.GetPostBackClientHyperlink(btnUpdate, "")  
  4.  
  5. If not page.isPostback then  
  6.  
  7. Dropdownlist1.Attributes.add("onchange","ConfirmUpdate(""" & sCmd & """)")  
  8.  
  9. End if 

ConfirmUpdate函數如下

  1. ﹤Script language=”javascript”﹥  
  2.  
  3. function ConfirmUpdate(cmd){  
  4.  
  5. if confirm(“Are you sure to update?”)  
  6.  
  7. eval(cmd);  
  8.  
  9. }﹤/Script﹥ 

這里利用了JavaScript eval函數來調用一個字符串中包含的命令。需注意的是包含命令的字符串不能用單引號括起來,因為自動生成的腳本中包括單引號,所以這里用兩個雙引號表示字符串本身的雙引號。

三、ASP.NET中JavaScript插入的結束語

以上簡單討論了在ASP.Net中插入Javascript的幾種情況。合理地在服務器程序中插入客戶端的Javascript腳本,可以提高程序的運行效率并提供更友好的用戶界面。

ASP.NET中JavaScript插入的方法就介紹到這里,希望對此你有所了解。

【編輯推薦】

  1. ASP.NET MD5和SHA1加密方法的淺析
  2. ASP.NET學習之CSS實現多界面二大方法
  3. ASP.NET中Cookie編程基礎淺析
  4. ASP.NET編程習慣淺析
  5. ASP.NET JavaScript的頁面整合淺談
責任編輯:仲衡 來源: 博客堂
相關推薦

2009-08-04 17:28:45

Apache支持ASP

2009-07-22 14:23:39

URL RewriteASP.NET

2009-07-27 15:34:11

MembershipASP.NET

2009-07-27 10:18:12

TypeResolveASP.NET

2009-08-05 18:36:12

ASP.NET Che

2009-07-24 13:41:15

ASP.NET AJA

2009-08-05 15:50:13

ASP.NET優點

2009-07-31 12:43:59

ASP.NET MVC

2009-07-20 16:09:39

2009-07-24 10:53:51

ASP.NET實現靜態

2009-07-22 18:03:00

ASP.NET ASP

2009-07-30 13:28:55

ASP.NET中的ja

2009-08-10 13:32:15

ASP.NET TimASP.NET組件設計

2009-07-29 11:19:03

JavaScriptASP.NET

2009-07-27 10:22:16

ASP.NET中Coo

2009-04-08 09:58:07

ASP.NET MVCTempData框架

2009-07-21 10:05:10

ASP.NET配置文件

2009-07-29 14:12:45

ASP.NET tra

2009-07-28 10:59:13

ASP.NET IIS

2009-07-29 09:34:54

IsPostBack屬ASP.NET
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 韩日三级| 91久久久久久久久 | 91在线资源 | 久久精品亚洲一区二区三区浴池 | 久久亚洲一区二区三 | 伊人免费在线观看 | 日本天天操| 免费精品 | 中文精品久久 | 天天爽天天干 | 久久久www成人免费无遮挡大片 | 久久久影院| 久久噜噜噜精品国产亚洲综合 | 日本不卡高清视频 | 亚洲精品一区二区三区中文字幕 | 极品一区 | 欧美激情五月 | 日韩三级在线观看 | 欧美精品一区二区三 | 99精品视频在线观看免费播放 | 精品蜜桃一区二区三区 | 欧美a免费 | 91网站视频在线观看 | 国产h视频 | 成人国产一区二区三区精品麻豆 | 2019天天操 | 91精品国产综合久久久久 | 中文字幕亚洲视频 | 正在播放国产精品 | 欧美在线一区二区三区 | 在线观看特色大片免费网站 | 国产精品99视频 | 日本亚洲欧美 | 日韩视频在线观看中文字幕 | 91美女在线观看 | 国产精品美女久久久久aⅴ国产馆 | 在线免费观看黄视频 | 国产精品乱码一区二区三区 | 中文字幕在线观看第一页 | 日韩喷潮 | 2020天天操|