在 .NET 5 已經推出一段時日的今天,.NET 6 已經正式邁入 preview2 (正在撰寫本文的時候官方 release preview 3 了😂)階段。
隨著距離 .NET 6 正式版推出的時間越來越近,有越來越多捧友關心 Xamarin.Forms 在 .NET 6 中會如何改變。而如果使用 Xamarin.Forms 開發的觀念有正確的話,目前到 preview 3 的釋出結果來看,其實來說沒有太多的改變。
真要說最大的改變就是改名 MAUI 的全新感受吧! 所以就讓我們來一探究竟囉…
(本文章的內容截圖為 .NET 6 preview2 時完成,請捧友們斟酌對照觀看)
本著實驗的精神,並沒有從安裝 Visual Studio 2019 preview 的部分來開始,而是從 Download .NET 6 的部分(如上圖)來進行。
而本文要進行的部分是測試使用 .NET 6 中 MAUI 的部分,要安裝的東西確認有點繁瑣,但幸好一切的一切都有社群神人幫忙做了一個好工具:
MAUI-Check
https://github.com/Redth/dotnet-maui-check
而上述工具只要電腦上有 .NET CLI (安裝 .NET SDK 就有)就透過 命令提示字元 輸入:
dotnet tool install -g Redth.Net.Maui.Check
就會開始進行該套件工具的安裝
data:image/s3,"s3://crabby-images/87fa6/87fa6155ef5c3cdd1aa73d70a64b7aa0a1978bbf" alt=""
data:image/s3,"s3://crabby-images/48f1b/48f1b0340044d91b681101a49e6547c0b66010ee" alt=""
完成後就可以繼續在命令提示字元當中輸入:
maui-check
data:image/s3,"s3://crabby-images/4f003/4f003b6c7588d382147648e9d80c6b25b3444e3c" alt=""
就會看到 .NET MAUI Check 工具執行起來,並且開始進行相關環境的檢查作業:
data:image/s3,"s3://crabby-images/9fa21/9fa21d3d86b6bbd0f78cf1f99eeb91c7ff436d1b" alt=""
接著就依照工具的檢查跟需求來操作即可,也就是說有停下來詢問是否修正,都請按 'y' (若自己要打字回應也請注意要打小寫 'y')。
data:image/s3,"s3://crabby-images/13b72/13b72d634511ec57ae576b7374b9d926ed43f8c2" alt=""
啪搭…的一下到這個畫面的時候
data:image/s3,"s3://crabby-images/6c3e9/6c3e95f5199b163741c67d5cb29d75a07d9939e3" alt=""
恭喜,完成檢查。
接著請按任意鍵離開 MAUI Check,回到命令提示字元。
data:image/s3,"s3://crabby-images/74757/7475733d1e972298fc0f1684b8e167ed6560e47e" alt=""
接著繼續在命令提示字元裡面切換資料夾位置並建立資料夾。
data:image/s3,"s3://crabby-images/655ea/655ea7d5e8b7de50306f1a3fdf6ca29fb00a09df" alt=""
然後鍵入指令(還有指令的其他選項,請自行參考 -h or --help):
dotnet new maui
data:image/s3,"s3://crabby-images/992a9/992a9a646b19226cd9048d6029b626bb00cd7e1f" alt=""
data:image/s3,"s3://crabby-images/2faed/2faed852ae20ef58215a307b6c3e861986e5f0f7" alt=""
再透過檔案總管看一下,啪搭…專案建立完成。
data:image/s3,"s3://crabby-images/82911/829118a01e57a23a48bf38fa81ac0712792615da" alt=""
再次回到命令提示字元輸入指令:
maui-check config -dev --nuget-sources
data:image/s3,"s3://crabby-images/f1846/f184675049932908f982f763afa0ec03a4832ec9" alt=""
讓 maui-check 工具幫你增加專案對應的開發 Nuget 下載位址,並且就會發現剛剛的專案資料夾下增加了 NuGet.config 檔案。
data:image/s3,"s3://crabby-images/adfaa/adfaabe2444b93b3327977ed785c21fe2aa69ae1" alt=""
再次回到命令提示字元當中輸入:
dotnet build
然後進入編譯時間😌
data:image/s3,"s3://crabby-images/90f33/90f333db18adda735dd6998b77beba3ea637049f" alt=""
拍搭啦~~~
data:image/s3,"s3://crabby-images/5a281/5a28170ac01d63f6a67a84170b3bc4a1da72f32f" alt=""
看到此畫面,恭喜建置完成。
接著請先啟動起一個 Android 的模擬器或實體裝置,並確定電腦的 adb 已有連結上該裝置。
繼續在命令提示字元中輸入:
dotnet build --no-restore -t:Run -f net6.0-android
data:image/s3,"s3://crabby-images/25507/255071c5fcf101159a6b18b48eed4eb6b025a02b" alt=""
data:image/s3,"s3://crabby-images/cfe8a/cfe8a487a2478a6161ac65ae29a9680fe021c140" alt=""
data:image/s3,"s3://crabby-images/b0cb1/b0cb120ae36f8c0b6029ed6dfbcc8b72ed283e55" alt=""
看到上述畫面確認編譯成功。
接著就會看到開始將專案部屬到 Android 的裝置中(本文使用模擬器測試)。
data:image/s3,"s3://crabby-images/1490b/1490b545535d6281e83ee8c30002b76fc5584518" alt=""
測試玩一下。
data:image/s3,"s3://crabby-images/69b99/69b999bc6ffd626b77a3fe27fd81ec55bd544ba6" alt=""
以上介紹,僅僅單純的使用 dotnet 的 CLI 指令與命令提示字元完成相關 MAUI 操作。
註一: 本文撰寫時並未安裝 "Visual Studio 2019 preview" IDE 工具。
註二: 本文內容在測試時是 .NET 6 preview2 的時候,編寫文章時已經推出 .NET 6 preview3。
下列參考文獻:
- Announcing .NET 6 Preview 2:
https://devblogs.microsoft.com/dotnet/announcing-net-6-preview-2/ - GitHub dotnet/maui:
https://github.com/dotnet/maui - GitHub dotnet/net6-mobile-samples:
https://github.com/dotnet/net6-mobile-samples - Goodbye Xamarin.Forms, Hello MAUI!
https://www.syncfusion.com/blogs/post/goodbye-xamarin-forms-hello-maui.aspx - Visual Studio 2019 preview:
https://docs.microsoft.com/zh-tw/visualstudio/releases/2019/release-notes-preview
I'm a Microsoft MVP - Developer Technologies (From 2015 ~).
data:image/s3,"s3://crabby-images/955ea/955eaffa14ee58e8d34c1d65177a23418424c8f9" alt="MVP_Logo"
I focus on the following topics: Xamarin Technology, Azure, Mobile DevOps, and Microsoft EM+S.
If you want to know more about them, welcome to my website:
https://jamestsai.tw
本部落格文章之圖片相關後製處理皆透過 Techsmith 公司 所贊助其授權使用之 "Snagit" 與 "Snagit Editor" 軟體製作。