通過Blazor使用C#開發SPA單頁面應用程式(1)

来源:https://www.cnblogs.com/liuxtj/archive/2019/08/13/11344539.html
-Advertisement-
Play Games

2019年9月23——25日 .NET Core 3.0即將在.NET Conf上發佈! .NET Core的發佈及成熟重燃了.net程式員的熱情和希望,一些.net大咖也在積極的為推動.NET Core而不懈的努力。在這次.NET Core 3.0中一項新的技術也首次出現在人們的視野,這就是Bla ...


    2019年9月23——25日 .NET Core 3.0即將在.NET Conf上發佈! .NET Core的發佈及成熟重燃了.net程式員的熱情和希望,一些.net大咖也在積極的為推動.NET Core而不懈的努力。在這次.NET Core 3.0中一項新的技術也首次出現在人們的視野,這就是Blazor。說起Blazor也許許多人並不知曉,但這幾年一片熱火朝天的Angular,React,Vue等前端技術估計無人不知無人不曉。對Blazor就是Microsoft提供的使用C#構建SPA的技術,雖然他姍姍來遲,但帶給了大家一個與Angular,React,Vue等框架完全不一樣的體驗、完全不一樣的架構。

    由於這是一個全新的技術,目前學習資料非常有限,我將自己學習到的內容記錄彙總在這裡以便查閱,也給感興趣的童鞋提供參考。

1.    簡介

    Blazor是一個新的Web UI框架,使用C#,Razor和HTML以及WebAssembly (W3C標準)。它允許您使用C#而不是JavaScript構建互動式Web UI。Blazor應用程式由使用C#,HTML和CSS實現的可重用Web UI組件組成。客戶端和伺服器代碼都是用C#編寫的,允許您共用代碼和庫。

2.    在WebAssembly或伺服器上運行

    Blazor可以使用WebAssembly直接在瀏覽器中運行客戶端C#代碼。因為它是在WebAssembly上運行的真實.NET,所以您可以從應用程式的伺服器端部分重用代碼和庫(客戶端渲染)。

或者,Blazor可以在伺服器上運行您的客戶端邏輯。客戶端UI事件使用SignalR(實時消息傳遞框架)發送回伺服器。執行完成後,所需的UI更改將發送到客戶端併合併到DOM中(伺服器端渲染)。

3.    Web Assembly (Wasm)

    基於W3C開放標準,用於在瀏覽器中運行低級位元組代碼。使用此標準,我們可以直接在瀏覽器中運行伺服器端語言(Rust,C ++,C#...)而不是Javascript。

    還記得Java applet和Microsoft Silverlight嗎,我們必須在瀏覽器中安裝插件來運行Java和C#代碼,但是WebAssembly提供了基本標準,現在我們不需要任何插件,他的二進位格式以.wasm文件表示,能夠提供接近本機的性能。

4.    建立在開放的Web標準之上

    Blazor使用開放的Web標準,沒有插件或代碼轉換。Blazor適用於所有現代Web瀏覽器,包括移動瀏覽器。

    在瀏覽器中運行的代碼在與JavaScript框架相同的安全沙箱中執行。

 

Blazor 客戶端渲染支持的瀏覽器

瀏覽者

版本

Microsoft Edge

當前

Mozilla Firefox

當前

Google Chrome, 包括 Android

當前

Safari, 包括 iOS

當前

Microsoft Internet Explorer

不支持 *

* Microsoft Internet Explorer 不支持WebAssembly。

Razor 伺服器端渲染支持的瀏覽器

瀏覽者

版本

Microsoft Edge

當前

Mozilla Firefox

當前

Google Chrome, 包括 Android

當前

Safari, 包括 iOS

當前

Microsoft Internet Explorer

11x17 *

*需要額外的填充代碼 (例如, 可通過Polyfill.io捆綁添加承諾)。

5.    單頁面應用程式(SPA)

    單頁面應用程式(SPA)是一種構建在瀏覽器中單個頁面上的Web應用程式,頁面塊可以動態呈現而無需呈現完整的頁面。

Angular,React,Vue和許多其他語言為構建SPA提供了支持,但所有這些語言都構建在相同的Javascript語言之上。現在,Microsoft提供了使用C#和Razor頁面構建SPA的基礎,類似ASP.Net Core中的語法,所以它被稱為Blazor。

    Blazor是ASP.Net Core提供的新的Web框架,用於在瀏覽器中使用C#和WebAssembly標準構建SPA。

    ASP.Net Core是一個在Linux,Mac或Windows操作系統上運行的開源Web框架。

6.    JavaScript互操作

    C#代碼可以輕鬆調用JavaScript API和庫。在C#中編寫邏輯時,您可以繼續使用存在於客戶端UI中的大型JavaScript庫生態系統。當然如果願意您還可以從 JavaScript 調用 .NET 實例方法和靜態方法。

7.    優點

  • 受益於 .NET 的性能、可靠性和安全性,提供近乎原生的性能,高效且便攜
  • 使用 C# 代替 JavaScript 來編寫代碼。
  • 利用現有的 .NET 庫生態系統,我們可以在網頁中使用現有的豐富.net生態系統功能。
  • 在伺服器和客戶端之間共用應用邏輯。
  • 始終高效支持 Windows、Linux 和 macOS 上的 Visual Studio。
  • 以一組穩定、功能豐富且易用的通用語言、框架和工具為基礎來進行生成。
  • 碼維護和調試更可靠。

8.    缺點

  • Javascript已經非常成熟,許多組件庫已經存在於市場中。
  • 具有Web Assembly標準的Blazor是市場上的新手,需要時間才能成熟,而且.net是WebAssembly眾多實現中的早期版本。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本章主要和大家分享下在ASP.NET MVC中我們的Action如何向視圖傳遞匿名類型的值。 ...
  • 1、在電腦科學中,二叉樹是每個結點最多有兩個子樹的樹結構。通常子樹被稱作“左子樹”(left subtree)和“右子樹”(right subtree)。(百度百科) 廣度優先搜索(Breadth First Search),又叫寬度優先搜索或橫向優先搜索,是從根結點開始沿著樹的寬度搜索遍歷,上面 ...
  • 一、Web Service 1、定義 是可以接收從Internet上的其他系統中傳遞的請求,是一種輕量級的獨立的通訊技術, 能使得運行在不同機器上的不同應用無須藉助附加的、專門的第三方軟體或硬體, 就可相互交換數據或集成。所以它是一個平臺獨立,低耦合,自包含,基於可編程的Web應用程式,適用於開發分 ...
  • 後端處理:var callback=context.Request.QueryString["callback"].ToString(); context.Response.Write($"{callback}({SerializeObject(result)})"); result為返回的數據 前 ...
  • (雙擊全屏播放) 一、前言 為什麼選擇Hyper-V? windowns自帶,免費 基礎環境 二、虛擬機配置 下載CentOS7鏡像 https://www.centos.org/download/ 此次安裝使用的版本為:CentOS-7-x86_64-Minimal-1611.iso 打開Hype ...
  • PostgreSQL是一個功能強大的開源資料庫系統。它支持了大多數的SQL:2008標準的數據類型,包括整型、數值值、布爾型、位元組型、字元型、日期型、時間間隔型和時間型,它也支持存儲二進位的大對像,包括圖片、聲音和視頻。PostgreSQL對很多高級開發語言有原生的編程介面,如C/C++、Java、... ...
  • 大家好,前幾天因工作需要要開發一個基於WinForm的小程式。其中要用到分頁,最開始的想法找個第三方的dll用一下,但是後來想了想覺得不如自己寫一個玩一下 之前的web開發中有各式各樣的列表組件基本都帶有分頁功能,筆者早先也自己寫過B/S端的分頁組件(利用jquery純前端方式)。對於WinForm ...
  • Virtual方法(虛方法) Virtual方法(虛方法) virtual 關鍵字用於在基類中修飾方法。virtual的使用會有兩種情況: 情況1:在基類中定義了virtual方法,但在派生類中沒有重寫該虛方法。那麼在對派生類實例的調用中,該虛方法使用的是基類定義的方法。 情況2:在基類中定義了vi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...