從 Windows Forms .NET Framework 移轉至 .NET
本文說明如何使用 .NET Upgrade Assistant 將 Windows Forms 傳統型應用程式升級至 .NET。 Windows Forms 仍然是僅限 Windows 的架構,即使 .NET 是跨平台技術也一樣。
必要條件
- Windows 作業系統。
- 下載並解壓縮本文使用的示範應用程式。
- Visual Studio 2022 17.12 版或更新版本的目標為 .NET 9。
- 適用於 Visual Studio 的 .NET 升級小幫手延伸模組。
評量
您應該先分析您的專案,再執行升級。 使用 .NET Upgrade Assistant 對專案執行程式代碼分析會產生您可以參考的報告,以識別潛在的移轉封鎖程式。
若要分析您的項目併產生報告,請以滑鼠右鍵按兩下 方案總管 中的方案檔,然後選取 [升級]。 如需執行分析的詳細資訊,請參閱 使用 .NET Upgrade Assistant 分析專案。
移轉相依性
如果您要升級多重專案,請從沒有相依性的專案開始。 在比對遊戲範例中,MatchingGame 專案相依於 MatchingGame.Logic 程式庫,因此應先升級 MatchingGame.Logic。
提示
請務必備份您的程式碼,例如在原始檔控制或複本中。
使用下列步驟升級 Visual Studio 中的專案:
以滑鼠右鍵按一下 [方案總管] 視窗中的 MatchingGame.Logic 專案,然後選取 [升級]:
隨即開啟新的索引標籤,提示您選擇要執行的升級。
選取 [就地專案升級]。
接下來,選取目標 Framework。
根據您要升級的專案類型,系統會顯示不同的選項。 .NET Framework 和 .NET 都可以使用 .NET Standard 2.0。 如果連結庫不依賴像 Windows Forms 這樣的桌面技術,則這是一個很好的選擇。此專案會如此。
選取 [.NET 9.0 ],然後選取 [ 下一步]。
樹狀結構會顯示與專案相關的所有成品,例如程式碼檔案和程式庫。 您可以升級個別成品或整個專案,這是預設值。 選取 [升級選取項目] 以開始升級。
升級完成時,會顯示結果:
已升級具有實心綠色圓圈的成品,同時略過空的綠色圓圈。 略過的成品表示升級小幫手找不到任何升級項目。
現在已升級應用程式的支援程式庫,請升級主應用程式。
Visual Basic 專案的注意事項
目前,.NET 升級小幫手無法辨識 System.Configuration
在 .NET Framework 上 Visual Basic 範本所建立的設定檔中使用 。 它也不尊重使用 My
.NET Framework 專案中所使用的延伸模組,例如 My.Computer
和 My.User
。 這些延伸模組已在 .NET 中移除。 由於這兩個問題,使用 .NET Upgrade Assistant 進行移轉之後,Visual Basic 連結庫將不會編譯。
若要修正此問題,項目必須以 Windows 為目標並參考 Windows Forms。
- 移轉完成後,按兩下 [方案總管] 視窗中的 [MatchingGame.Logic] 專案。
- 找到
<Project>/<PropertyGroup>
項目。 - 在 XML 編輯器中,將的值
<TargetFramework>
從net9.0
變更為net9.0-windows
。 - 將 新增
<UseWindowsForms>true</UseWindowsForms>
至 之後<TargetFramework>
的行。
項目設定看起來應該像下列代碼段:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net9.0-windows</TargetFramework>
<UseWindowsForms>true</UseWindowsForms>
<OutputType>Library</OutputType>
<MyType>Windows</MyType>
... other settings removed for brevity ...
移轉主要專案
升級所有支援程式庫之後,即可升級主應用程式專案。 使用範例應用程式時,只有一個要升級的程式庫專案,已在上一節中升級。
- 以滑鼠右鍵按一下 [方案總管] 視窗中的 MatchingGame 專案,然後選取 [升級]:
- 選取 [就地專案升級]。
- 選取 目標 Framework 的 .NET 9.0 ,然後選取 [ 下一步]。
- 保留選取的所有成品,然後選取 [升級選取項目]。
升級完成後,會顯示結果。 請注意,Windows Forms 專案是如何產生警告符號。 展開該項目,並顯示有關該步驟的詳細資訊:
請注意,專案升級元件提到預設字型已變更。 因為字型可能會影響控件版面配置,因此您必須檢查專案中的每個表單和自定義控件,以確保UI已正確排列。
產生全新組建
升級主要專案之後,請清除專案並加以編譯。
- 以滑鼠右鍵按一下 [方案總管] 視窗中的 MatchingGame 專案,然後選取 [清除]。
- 以滑鼠右鍵按一下 [方案總管] 視窗中的 MatchingGame 專案,然後選取 [組建]。
如果您的應用程式發生任何錯誤,您可以在 [錯誤清單] 視窗中找到這些錯誤,以及如何修正這些錯誤的建議。
Windows Forms 比對遊戲範例 專案現在已升級至 .NET 9。
升級后體驗
如果您要將應用程式從 .NET Framework 移植到 .NET,請檢閱 從 .NET Framework 升級到 .NET 之後的現代化一文。
相關內容
-
移植指南提供將程式碼從 .NET Framework 移植到 .NET 時應考量項目的概觀。 專案的複雜度會決定在專案檔初始移轉之後,您將執行多少工作。
從 .NET Framework 升級至 .NET 之後進行現代化。
自 .NET Framework 推出以來,.NET 的世界發生了很大的變化。 此連結提供有關如何在升級后將應用程式現代化的一些資訊。