亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

關于ASP.NET調用JavaScript的實現

2019-11-18 16:46:46
字體:
來源:轉載
供稿:網友

本文結合示例講述了在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仍然很有必要。


二、Javascript的應用示例

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

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

if not page.isPostBack() then

btnSave.Attributes.Add(“onclick”,”Javascript:return confirm(‘Are you sure to save?’);”)

end if

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


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

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

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

<asp:datagrid id="grd1" runat="server" OnItemDataBound = "ItemDataBound" >

…Columns definition here

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


Sub ItemDataBound(ByVal sender As Object, ByVal e As DataGridItemEventArgs)

If e.Item.ItemType <> ListItemType.Header And e.Item.ItemType <> ListItemType.Footer Then

Dim oDeleteButton As LinkButton = e.Item.Cells(5).Controls(0)

oDeleteButton.Attributes("onclick") = "javascript:return Confirm ('Are you sure you want to delete" & DataBinder.Eval(e.Item.DataItem, "m_sName") & "?')"

End If

End Sub

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


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

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

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

PRotected Sub ItemEdit(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs)

Dim sDateCtrl as string

sDateCtrl = grd1. Items (e.Item.ItemIndex) . Cells(2). FindControl("txtDate") . ClientID

End Sub

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


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

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

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

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

Sub Item_Bound(ByVal sender As Object, ByVal e As DataGridItemEventArgs )

Dim itemType As ListItemType

itemType = CType(e.Item.ItemType, ListItemType)

If (itemType <> ListItemType.Header) And _

(itemType <> ListItemType.Footer) And _

(itemType <> ListItemType.Separator) Then

Dim oSelect As LinkButton = CType(e.Item.Cells(5).Controls(0), LinkButton)

e.Item.Attributes("onclick") = Page. GetPostBackClientHyperlink (oSelect, "")


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方法如下:

Dim sCmd as string

sCmd=Page.GetPostBackClientHyperlink(btnUpdate, "")

If not page.isPostback then

Dropdownlist1.Attributes.add("onchange","ConfirmUpdate(""" & sCmd & """)")

End if


ConfirmUpdate函數如下

<Script language=”javascript”>

function ConfirmUpdate(cmd){

if confirm(“Are you sure to update?”)

eval(cmd);

}

</Script>

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

三、結束語

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美超级免费视 在线| 国产精欧美一区二区三区| 国产精品亚洲综合天堂夜夜| 国产亚洲欧洲在线| 91在线中文字幕| 日韩毛片在线看| 亚洲欧美中文字幕在线一区| 久久久久久久久中文字幕| 亚洲美女视频网| 91国自产精品中文字幕亚洲| 日韩有码在线视频| 91精品久久久久久久久久| 91香蕉嫩草神马影院在线观看| 国产精品久久色| 在线精品视频视频中文字幕| 久久久91精品国产| 欧美大片网站在线观看| 久久久久久综合网天天| 97激碰免费视频| 黄色91在线观看| 色综合老司机第九色激情| 久久久久久久久久国产精品| 亚洲人成自拍网站| 亚洲偷熟乱区亚洲香蕉av| 在线精品91av| 在线成人激情黄色| 亚洲另类欧美自拍| www.精品av.com| 91人人爽人人爽人人精88v| 欧美久久久精品| 蜜臀久久99精品久久久无需会员| 日本久久久久久久| 伊人久久综合97精品| 欧美激情第三页| 中文字幕亚洲在线| 欧美在线视频免费观看| 精品美女国产在线| 日韩欧美成人免费视频| 欧美大胆在线视频| 欧美日韩精品中文字幕| 成人网在线免费看| 精品国产一区二区三区久久狼黑人| 国产精品久久97| 精品无人区太爽高潮在线播放| 国产精品偷伦视频免费观看国产| 国产欧美日韩丝袜精品一区| 欧美性极品少妇精品网站| 这里精品视频免费| 伊人久久免费视频| 亚洲国产中文字幕在线观看| 永久免费看mv网站入口亚洲| 亚洲精品久久视频| 麻豆一区二区在线观看| 不卡av在线网站| 国产成人亚洲综合91| www日韩中文字幕在线看| 国产免费一区视频观看免费| 国产精品久久久久久久久久久久久| 色中色综合影院手机版在线观看| 国产精品一区二区久久精品| 日韩av在线电影网| 在线视频欧美日韩精品| 久久91亚洲精品中文字幕| 亚洲三级免费看| 亚洲精品美女在线观看播放| 久久精品欧美视频| 欧美日韩一区二区在线播放| 国产精品jizz在线观看麻豆| 成人高清视频观看www| 亚洲精品国精品久久99热| www.色综合| 色爱av美腿丝袜综合粉嫩av| 久久精品久久久久电影| 91久久久久久| 中文字幕欧美精品在线| 精品国产成人av| 亚洲精品国产精品国产自| 亚洲精品成人av| 欧美日韩国产精品| 91九色视频在线| 久久成人精品电影| 欧美激情一级欧美精品| 精品亚洲夜色av98在线观看| 色综合影院在线| 91免费高清视频| 日本久久久久久久久久久| 国产在线观看91精品一区| 乱亲女秽乱长久久久| 亚洲a∨日韩av高清在线观看| 欧美肥婆姓交大片| 日韩av毛片网| 中文字幕亚洲欧美日韩在线不卡| 久久男人av资源网站| 亚洲一区免费网站| 欧美日本啪啪无遮挡网站| 国产精品久久91| 伊人久久久久久久久久久久久| 国产精品久久久久久久久久免费| 国产精品91久久久| 成人写真视频福利网| 自拍偷拍免费精品| 92看片淫黄大片欧美看国产片| 91久久在线观看| 欧美日韩另类字幕中文| 日韩电影第一页| 91国产视频在线播放| 懂色aⅴ精品一区二区三区蜜月| 国产精品jizz在线观看麻豆| www日韩中文字幕在线看| 亚洲一区中文字幕在线观看| 在线看国产精品| 亚洲aa中文字幕| 精品magnet| 欧美尤物巨大精品爽| 68精品国产免费久久久久久婷婷| 一本一本久久a久久精品综合小说| 亚洲自拍偷拍网址| 国产一区二区色| 热久久美女精品天天吊色| 国产欧美日韩精品在线观看| 亚洲国产精品中文| 日韩高清有码在线| 韩国国内大量揄拍精品视频| 国产大片精品免费永久看nba| 日韩在线观看免费全集电视剧网站| 91精品在线观看视频| 韩剧1988免费观看全集| 爽爽爽爽爽爽爽成人免费观看| 福利视频一区二区| 深夜福利国产精品| 亚洲最大的免费| 亚洲国产婷婷香蕉久久久久久| 日韩精品免费电影| 午夜精品久久久久久久99热| 国产精品久久久久久久久久新婚| 欧美精品电影免费在线观看| 日韩电视剧在线观看免费网站| 69视频在线播放| 精品视频久久久| 欧美精品在线视频观看| 久久久综合免费视频| 欧美在线观看网址综合| 亚洲精品在线看| 国产在线精品一区免费香蕉| 亚洲欧美日韩精品久久| 91在线色戒在线| 一个人www欧美| zzijzzij亚洲日本成熟少妇| 91久久久久久久一区二区| 色综合久综合久久综合久鬼88| 欧美一级黄色网| 日本精品免费一区二区三区| 亚洲人成五月天| 久久综合免费视频影院| 国产精品专区h在线观看| 亚洲图片欧美日产| 欧美午夜精品久久久久久人妖| 亚洲一区二区福利| 精品亚洲一区二区三区在线观看| 91探花福利精品国产自产在线| 欧美福利视频网站| 精品呦交小u女在线| 国产一区二区久久精品| 国产在线日韩在线|