ASP.NET編程中的十大技巧
在本篇文件中,我們將討論編程人員在使用ASP.NET開發應用程序時需要注意的10個技巧,這些技巧涉及從缺省的控件、表單名的改變到StringBuilder類的使用,有助于編程人員能夠盡快地適應.NET環境。
??
? 1、在使用Visual Studio .NET時,除直接或非引用的對象外,不要使用缺省的名字。
??
? .NET帶來的好處之一是所有的源代碼和配置文件都是純文本文件,能夠使用Notepad或WordPad等任意的文本編輯器進行編輯。如果不愿意,我們并非一定要使用Visual Studio .NET作為集成開發環境。但使用了Visual Studio .NET,我們可以在Windows文件管理器中看到文件,或在Visual Studio .NET之外從文本編輯器中瀏覽文件的內容。
? 使用Visual Studio .NET作為集成開發環境有許多好處,其中最顯著的好處是它極大地提高了生產效率。使用Visual Studio. NET,我們能夠在付出較小代價的情況下更快地開發軟件。作為集成開發環境一部分的IntelliSense提供自動的代碼完成、在輸入方法或函數時提供動態幫助、語法錯誤的實時提示,以及其他能夠提高生產效率的功能。
? 象其他復雜的工具那樣,在學會如何充分發揮它的作用和掌握其“習性”前,Visual Studio .NET也會使我們產生一種挫折感。有時,它象一個難以了解的黑盒子,會生成大量的文件和許多無用的代碼。
? Visual Studio .NET的一個功能是,無論是類、控件或表單中的對象,它都能夠為新對象提供缺省名字。例如,如果我們創建了一個新的ASP.NET Web Application,其缺省的名字將是WebApplication1。我們可以在“新工程”對話框中方便地改變該應用的名字,但同時改變的只是該應用程序的名字空間的名字及其所在的虛擬目錄,源代碼文件的缺省名字仍然是WebForm1.aspx和WebForm1.aspx.cs(C#工程)或WebForm1.aspx.vb(VB.NET工程)。
??
? 我們可以在方案瀏覽器中改變ASPX和代碼使用的文件名字,但Web頁類的名字仍然將是WebForm1。如果在該Web表單上生成一個按鈕,其缺省的名字將是Button1。事實上,所有控件的名字都是由控件的類型和數字組成的。
? 我們能夠,也應該將應用程序中所有的表單和控件的名字都修改成有意義的名字。對于較小的演示性程序而言,缺省的名字還能夠勝任,但如果應用程序由多個表單,每個表單上有許多按鈕和標簽時,象frmStartup、frmDataEntry和frmReports這樣的表單名就比Form1、Form2和Form3這樣的名字更易于理解和維護。
? 如果表單上控件要在代碼的其他地方引用,使它有一個有意義的名字就更重要了。btnOK、btnCancel和btnPrint這樣的名字使看代碼的人更容易理解,因而,也比名字為Button1、Button2、Button3這樣的控件更容易維護。
? 修改一個工程中所有文件中出現的一個名字的一個好方法是,在Visual Studio .NET菜單中依次選擇“編輯”->“發現和替換”->“替換”命令。
? 在看二周前編寫的代碼時,我們經常就象第一次見到這些代碼一樣,因此使它們有一個有助于我們理解其含義的名字是十分有必要的。
??
??
? 2、即使不使用Visual Studio .NET進行編程,使用代碼支持文件也有利于提高應用程序的性能
??
? 在Web應用程序、Web服務或Web控件等所有的ASP.NET Web工程中,Visual Studio .NET都使用代碼支持文件。代碼支持文件使工程具有更好的組織、模塊性,更適合多人組成的開發團隊。另外,它還會帶來性能的提高。
? 代碼支持文件的內容被編譯成一個組合文件中的類,一般是一個DLL文件,有時也可以是EXE文件。該文件駐留在應用程序的組合體高速緩沖區中,在應用程序啟動時,可以立即得到它。
? 如果代碼是包含在
??
?
?
?
??
?
String Concatenation Benchmark
??
? Concatenation:
? ? id="lblConcat"
? runat="server"/>
??
?
??
? ? id="lblConcatString"
? runat="server"/>
??
?
?
??
? StringBuilder:
? ? id="lblBuild"
? runat="server"/>
??
?
??
? ? id="lblBuildString"
? runat="server"/>
??
?
?
?
? 二種方式的差別是相當大的:使用StringBuilder類的Append方法的速度比使用字符串連接的速度快近200倍。比較的結果如下所示:
? (圖:picture01)
??
??
? 5、只在必要時使用服務器端控件
??
? ASP.NET中新引入了一種在服務器端運行的被稱作Web Server Controls的控件,在代碼中,它們經常通過下面的語法被說明:
??
?
? 它們有時也被稱作ASP控件。服務器端控件是由runat屬性指示的,它的值總是“server”。
? 通過添加runat屬性,一般的HTML控件可以被很方便地轉換到服務器端運行,下面是一個簡單的例子:
??
?
? 可以通過id屬性中指定的名字,我們可以引用程序中的控件,可以通過編程的方式設置屬性和獲得值,因此,服務器端處理方式有較大的靈活性。
??
? 這種靈活性是有一定代價的。每種服務器端控件都會消耗服務器上的資源。另外,除非控件、網頁或應用程序明確地禁止view state,控件的狀態是包含在view state的隱藏域中,并在每次回送中都會被傳遞,這會引起嚴重的性能下降。
? 在這方面的一個很好的例子是,網頁上控件表格的應用,如果不需要在代碼中引用表格中的元素,則使用無需進行服務器端處理的HTML表格。我們仍然可以在HTML表格單元中放置服務器控件,并在代碼中引用服務器控件。如果需要引用任意的表格元素,例如指定的單元,則整個表格必須是服務器控件。
??
??
? 6. HyperLink控件、LinkButton控件的差別
??
? 對于Web訪問者而言,HyperLink、LinkButton控件是一樣的,但它們在功能方面仍然有較大的差異。
? 當用戶點擊控件時,HyperLink控件會立即將用戶“導航”到目標URL,表件不會回送到服務器上。LinkButton控件則首先將表件發回到服務器,然后將用戶導航到目標URL。如果在“到達”目標URL之前需要進行服務器端處理,則使用LinkButton控件;如果無需進行服務器端處理,則可以使用HyperLink控件。
??
??
? 7、注釋代碼
??
? 這一技巧并不是針對ASP.NET的,但它是一個良好的編程習慣。
? 注釋不僅僅應當說明代碼會執行什么操作,還應當注明原因。例如,不要僅僅在注釋中說明是在遍歷數組,而是要說明遍歷數組是根據某一算法計算一個值,除非算法是相當簡單的,否則還應當對算法進行簡要的說明。
? .NET工程中的不同的編程語言都有各自不同的注釋符號,下面是一個簡要的說明:
? HTML
? JavaScript // 注釋
? VBScript ' 注釋
? VB.NET ' 注釋
? C# // 注釋
? /* 多行內容
? 的注釋
? */
? SQL -- 注釋
??
? 在服務器控件的開始和結束標記中沒有注釋符號,但服務器能夠忽略掉所有它不能識別的屬性,因此我們能夠通過使用沒有定義的屬性來插入注釋。下面是一個例子:
??
? ? id="txtLastName"
? size="40"
? comment="這是我的注釋"
? runat="server" />
? 在Visual Studio .NET中對源代碼進行注釋非常簡單。高亮度顯示需要注釋的行,然后按Ctrl+K+C組合鍵添加注釋。要刪除注釋,只需高亮度顯示被注釋的代碼,并按下Ctrl+K+U組合鍵。
? 在C#工程中,我們還可以通過在每行的開始處使用///輸入XML注釋小節。在注釋小節中,我們可以使用下面的XML標記組織注釋:
?
?
?
?
?
? 要在Visual Studio .NET中查看這些XML注釋的格式化的報告,我們可以首先選擇“工具”菜單項,然后選擇“建立注釋Web網頁”菜單項。
??
??
? 8、使用trace方法和trace屬性記錄Page目錄中網頁的執行情況
??
? 調試程序的一種古老的技術是在程序中的關健點插入輸出語句,通常情況下,輸出信息中會包含重要變量的值,相關信息可以輸出到屏幕、日志文件或者數據庫。
? 在ASP.NET中,通過使用Page命令中的trace屬性,這種調試技術的使用更簡單了。Page命令是ASPX文件開始處的一行代碼,它提供編譯器的指示。Page命令中包含一個或多個屬性,向編譯器提供使用的編程語言、代碼支持文件的位置或要繼承的類的名字等信息。
? Page命令中的屬性之一是trace,其值可能是true或false,下面是一個典型的Page命令,其中的trace屬性的值是true:
??
?
??
? 如果trace屬性的值設置為true,由ASPX文件生成的Web頁就會顯示出來,除了網頁本身外,關于該頁的大量其他信息也會顯示出來。這些信息以下面小節的形式顯示在一張表格中:
? ·Request細節 提供Session ID、請求時間和請求的狀態碼。
? ·Trace Information 包含跟蹤日志、網頁生命周期中按時間先后順序各個步驟的列表。另外,也可以向其中添加定制信息。
? ·控件樹 以一種分層次的方式列出網頁上的所有控件,包括每個控件以字節計算的大小。
? ·Cookies集合 列出該網頁創建的所有Cookie。
? ·頭部集合 HTTP頭部以及它們的值。
? ·Server變量 與該網頁相關的Server環境變量。
??
? 包含在Trace Information小節中的跟蹤日志是最有用的,在這里我們可以插入自己的跟蹤命令。trace類中有2個方法能夠在跟蹤日志中插入命令:Trace.Write和Trace.Warn,除了Trace.Warn命令用紅色字體顯示、Trace.Write命令用黑色字體顯示外,它們是相同的。下面是跟蹤日志的一個屏幕快照,其中包含有幾個Trace.Warn命令。
??
? 跟蹤日志中最方便的功能是我們可以在開發和測試過程中在整個代碼中插入Trace.Write和Trace.Warn語句,而在最終交付應用程序時,可以通過改變Page命令中trace屬性的值,禁止這些命令起作用,而無需在部署應用軟件前刪除這些輸出語句。
??
??
? 9、使用存儲過程
??
? 微軟公司的SQL Server和其他現代關系數據庫都使用SQL命令定義和處理查詢。一個SQL語句或一系列SQL語句提交給SQL Server,SQL Server會對命令進行解析,然后創建一個查詢計劃并對它進行優化,然后執行該查詢計劃,這都需要大量的時間。
? 存儲過程是一系列被查詢處理器預解析和優化的SQL命令,這些命令會被存儲起來,可以得到快速地執行。存儲過程也被稱作sprocs,它可以接收輸入參數,使一個單一的存儲過程能夠處理較大范圍的特定的查詢。
? 因為sprocs是預先被解析的,對于復雜的查詢更顯得重要,其查詢計劃是預先優化的,因此調用查詢過程比執行相同功能的SQL語句速度要快得多。
??
??
? 10、使用.NET命令行
??
? .NET命令行工具在命令提示符窗口中運行。為了使命令能夠執行,它必須駐留在命令提示符的當前目錄中,或通過設置PATH環境變量。
? .NET SDK在“啟動”菜單上安裝一個菜單項,該菜單項能夠打開一個正確設置了PATH環境變量的命令提示符窗口。我們可以通過依次點擊“開始”->“程序”->“Microsoft Visual Studio .NET”->“Visual Studio .NET工具”->“Visual Studio .NET命令提示符”,啟動命令提示符窗口。
? 通過在將該菜單項從菜單上拖到桌面上時,同時按Ctrl+C鍵,就可以將該菜單項的快捷方式拷貝到桌面上,使用起來會非常方便。
??
? 1、在使用Visual Studio .NET時,除直接或非引用的對象外,不要使用缺省的名字。
??
? .NET帶來的好處之一是所有的源代碼和配置文件都是純文本文件,能夠使用Notepad或WordPad等任意的文本編輯器進行編輯。如果不愿意,我們并非一定要使用Visual Studio .NET作為集成開發環境。但使用了Visual Studio .NET,我們可以在Windows文件管理器中看到文件,或在Visual Studio .NET之外從文本編輯器中瀏覽文件的內容。
? 使用Visual Studio .NET作為集成開發環境有許多好處,其中最顯著的好處是它極大地提高了生產效率。使用Visual Studio. NET,我們能夠在付出較小代價的情況下更快地開發軟件。作為集成開發環境一部分的IntelliSense提供自動的代碼完成、在輸入方法或函數時提供動態幫助、語法錯誤的實時提示,以及其他能夠提高生產效率的功能。
? 象其他復雜的工具那樣,在學會如何充分發揮它的作用和掌握其“習性”前,Visual Studio .NET也會使我們產生一種挫折感。有時,它象一個難以了解的黑盒子,會生成大量的文件和許多無用的代碼。
? Visual Studio .NET的一個功能是,無論是類、控件或表單中的對象,它都能夠為新對象提供缺省名字。例如,如果我們創建了一個新的ASP.NET Web Application,其缺省的名字將是WebApplication1。我們可以在“新工程”對話框中方便地改變該應用的名字,但同時改變的只是該應用程序的名字空間的名字及其所在的虛擬目錄,源代碼文件的缺省名字仍然是WebForm1.aspx和WebForm1.aspx.cs(C#工程)或WebForm1.aspx.vb(VB.NET工程)。
??
? 我們可以在方案瀏覽器中改變ASPX和代碼使用的文件名字,但Web頁類的名字仍然將是WebForm1。如果在該Web表單上生成一個按鈕,其缺省的名字將是Button1。事實上,所有控件的名字都是由控件的類型和數字組成的。
? 我們能夠,也應該將應用程序中所有的表單和控件的名字都修改成有意義的名字。對于較小的演示性程序而言,缺省的名字還能夠勝任,但如果應用程序由多個表單,每個表單上有許多按鈕和標簽時,象frmStartup、frmDataEntry和frmReports這樣的表單名就比Form1、Form2和Form3這樣的名字更易于理解和維護。
? 如果表單上控件要在代碼的其他地方引用,使它有一個有意義的名字就更重要了。btnOK、btnCancel和btnPrint這樣的名字使看代碼的人更容易理解,因而,也比名字為Button1、Button2、Button3這樣的控件更容易維護。
? 修改一個工程中所有文件中出現的一個名字的一個好方法是,在Visual Studio .NET菜單中依次選擇“編輯”->“發現和替換”->“替換”命令。
? 在看二周前編寫的代碼時,我們經常就象第一次見到這些代碼一樣,因此使它們有一個有助于我們理解其含義的名字是十分有必要的。
??
??
? 2、即使不使用Visual Studio .NET進行編程,使用代碼支持文件也有利于提高應用程序的性能
??
? 在Web應用程序、Web服務或Web控件等所有的ASP.NET Web工程中,Visual Studio .NET都使用代碼支持文件。代碼支持文件使工程具有更好的組織、模塊性,更適合多人組成的開發團隊。另外,它還會帶來性能的提高。
? 代碼支持文件的內容被編譯成一個組合文件中的類,一般是一個DLL文件,有時也可以是EXE文件。該文件駐留在應用程序的組合體高速緩沖區中,在應用程序啟動時,可以立即得到它。
? 如果代碼是包含在
??
?
?
?
??
?
String Concatenation Benchmark
??
? Concatenation:
? ? id="lblConcat"
? runat="server"/>
??
?
??
? ? id="lblConcatString"
? runat="server"/>
??
?
?
??
? StringBuilder:
? ? id="lblBuild"
? runat="server"/>
??
?
??
? ? id="lblBuildString"
? runat="server"/>
??
?
?
?
? 二種方式的差別是相當大的:使用StringBuilder類的Append方法的速度比使用字符串連接的速度快近200倍。比較的結果如下所示:
? (圖:picture01)
??
??
? 5、只在必要時使用服務器端控件
??
? ASP.NET中新引入了一種在服務器端運行的被稱作Web Server Controls的控件,在代碼中,它們經常通過下面的語法被說明:
??
?
? 它們有時也被稱作ASP控件。服務器端控件是由runat屬性指示的,它的值總是“server”。
? 通過添加runat屬性,一般的HTML控件可以被很方便地轉換到服務器端運行,下面是一個簡單的例子:
??
?
? 可以通過id屬性中指定的名字,我們可以引用程序中的控件,可以通過編程的方式設置屬性和獲得值,因此,服務器端處理方式有較大的靈活性。
??
? 這種靈活性是有一定代價的。每種服務器端控件都會消耗服務器上的資源。另外,除非控件、網頁或應用程序明確地禁止view state,控件的狀態是包含在view state的隱藏域中,并在每次回送中都會被傳遞,這會引起嚴重的性能下降。
? 在這方面的一個很好的例子是,網頁上控件表格的應用,如果不需要在代碼中引用表格中的元素,則使用無需進行服務器端處理的HTML表格。我們仍然可以在HTML表格單元中放置服務器控件,并在代碼中引用服務器控件。如果需要引用任意的表格元素,例如指定的單元,則整個表格必須是服務器控件。
??
??
? 6. HyperLink控件、LinkButton控件的差別
??
? 對于Web訪問者而言,HyperLink、LinkButton控件是一樣的,但它們在功能方面仍然有較大的差異。
? 當用戶點擊控件時,HyperLink控件會立即將用戶“導航”到目標URL,表件不會回送到服務器上。LinkButton控件則首先將表件發回到服務器,然后將用戶導航到目標URL。如果在“到達”目標URL之前需要進行服務器端處理,則使用LinkButton控件;如果無需進行服務器端處理,則可以使用HyperLink控件。
??
??
? 7、注釋代碼
??
? 這一技巧并不是針對ASP.NET的,但它是一個良好的編程習慣。
? 注釋不僅僅應當說明代碼會執行什么操作,還應當注明原因。例如,不要僅僅在注釋中說明是在遍歷數組,而是要說明遍歷數組是根據某一算法計算一個值,除非算法是相當簡單的,否則還應當對算法進行簡要的說明。
? .NET工程中的不同的編程語言都有各自不同的注釋符號,下面是一個簡要的說明:
? HTML
? JavaScript // 注釋
? VBScript ' 注釋
? VB.NET ' 注釋
? C# // 注釋
? /* 多行內容
? 的注釋
? */
? SQL -- 注釋
??
? 在服務器控件的開始和結束標記中沒有注釋符號,但服務器能夠忽略掉所有它不能識別的屬性,因此我們能夠通過使用沒有定義的屬性來插入注釋。下面是一個例子:
??
? ? id="txtLastName"
? size="40"
? comment="這是我的注釋"
? runat="server" />
? 在Visual Studio .NET中對源代碼進行注釋非常簡單。高亮度顯示需要注釋的行,然后按Ctrl+K+C組合鍵添加注釋。要刪除注釋,只需高亮度顯示被注釋的代碼,并按下Ctrl+K+U組合鍵。
? 在C#工程中,我們還可以通過在每行的開始處使用///輸入XML注釋小節。在注釋小節中,我們可以使用下面的XML標記組織注釋:
?
?
?
?
?
? 要在Visual Studio .NET中查看這些XML注釋的格式化的報告,我們可以首先選擇“工具”菜單項,然后選擇“建立注釋Web網頁”菜單項。
??
??
? 8、使用trace方法和trace屬性記錄Page目錄中網頁的執行情況
??
? 調試程序的一種古老的技術是在程序中的關健點插入輸出語句,通常情況下,輸出信息中會包含重要變量的值,相關信息可以輸出到屏幕、日志文件或者數據庫。
? 在ASP.NET中,通過使用Page命令中的trace屬性,這種調試技術的使用更簡單了。Page命令是ASPX文件開始處的一行代碼,它提供編譯器的指示。Page命令中包含一個或多個屬性,向編譯器提供使用的編程語言、代碼支持文件的位置或要繼承的類的名字等信息。
? Page命令中的屬性之一是trace,其值可能是true或false,下面是一個典型的Page命令,其中的trace屬性的值是true:
??
?
??
? 如果trace屬性的值設置為true,由ASPX文件生成的Web頁就會顯示出來,除了網頁本身外,關于該頁的大量其他信息也會顯示出來。這些信息以下面小節的形式顯示在一張表格中:
? ·Request細節 提供Session ID、請求時間和請求的狀態碼。
? ·Trace Information 包含跟蹤日志、網頁生命周期中按時間先后順序各個步驟的列表。另外,也可以向其中添加定制信息。
? ·控件樹 以一種分層次的方式列出網頁上的所有控件,包括每個控件以字節計算的大小。
? ·Cookies集合 列出該網頁創建的所有Cookie。
? ·頭部集合 HTTP頭部以及它們的值。
? ·Server變量 與該網頁相關的Server環境變量。
??
? 包含在Trace Information小節中的跟蹤日志是最有用的,在這里我們可以插入自己的跟蹤命令。trace類中有2個方法能夠在跟蹤日志中插入命令:Trace.Write和Trace.Warn,除了Trace.Warn命令用紅色字體顯示、Trace.Write命令用黑色字體顯示外,它們是相同的。下面是跟蹤日志的一個屏幕快照,其中包含有幾個Trace.Warn命令。
??
? 跟蹤日志中最方便的功能是我們可以在開發和測試過程中在整個代碼中插入Trace.Write和Trace.Warn語句,而在最終交付應用程序時,可以通過改變Page命令中trace屬性的值,禁止這些命令起作用,而無需在部署應用軟件前刪除這些輸出語句。
??
??
? 9、使用存儲過程
??
? 微軟公司的SQL Server和其他現代關系數據庫都使用SQL命令定義和處理查詢。一個SQL語句或一系列SQL語句提交給SQL Server,SQL Server會對命令進行解析,然后創建一個查詢計劃并對它進行優化,然后執行該查詢計劃,這都需要大量的時間。
? 存儲過程是一系列被查詢處理器預解析和優化的SQL命令,這些命令會被存儲起來,可以得到快速地執行。存儲過程也被稱作sprocs,它可以接收輸入參數,使一個單一的存儲過程能夠處理較大范圍的特定的查詢。
? 因為sprocs是預先被解析的,對于復雜的查詢更顯得重要,其查詢計劃是預先優化的,因此調用查詢過程比執行相同功能的SQL語句速度要快得多。
??
??
? 10、使用.NET命令行
??
? .NET命令行工具在命令提示符窗口中運行。為了使命令能夠執行,它必須駐留在命令提示符的當前目錄中,或通過設置PATH環境變量。
? .NET SDK在“啟動”菜單上安裝一個菜單項,該菜單項能夠打開一個正確設置了PATH環境變量的命令提示符窗口。我們可以通過依次點擊“開始”->“程序”->“Microsoft Visual Studio .NET”->“Visual Studio .NET工具”->“Visual Studio .NET命令提示符”,啟動命令提示符窗口。
? 通過在將該菜單項從菜單上拖到桌面上時,同時按Ctrl+C鍵,就可以將該菜單項的快捷方式拷貝到桌面上,使用起來會非常方便。