Blazor VS React / Angular / Vue.js

原文作者: Christian Findlay
原文链接:https://christianfindlay.com/2020/06/04/blazor-vs-react-angular-vue-js/

Blazor是一项新的Microsoft技术,允许开发人员使用C#为浏览器编写代码, 本文将Blazor与其他三个常见SPA框架进行了比较:React,Angular和Vue.js, JavaScript是当前基于浏览器的单页应用程序(SPA)最受欢迎的语言,因为直到最近,它还是在浏览器中运行的唯一语言。这些框架可以从JavaScript或TypeScript进行编译或转换。本文询问开发人员是否需要依赖JavaScript,以及我们是否可以开始使用C#构建SPA应用程序。

什么是Blazor?

Blazor是用于Web和移动设备的基于.NET开发的SPA框架,并且是ASP.NET Core Web框架的一部分,Blazor使用现有的和大家熟悉的HTML文档对象模型(DOM)以及CSS样式来呈现和处理UI组件,但是,Blazor使用了C#来替代JavaScript进行处理,因此开发人员可以跨平台共享代码,Blazor使用Razor脚本声明HTML,这是.NET开发人员熟悉的脚本,Razor通过维护一种简单的语法来使开发人员接近HTML,并且允许数据绑定,循环和变量定义。

程序运行在.NET运行时上面,有服务器端和客户端两种模式,对于服务器端,HTML DOM呈现在服务器上,然后通过Signal-R 发送到浏览器,进行数据渲染, 对于客户端,Mono在浏览器内部的WebAssembly上运行,WASM 无需服务器端渲染或其他浏览器插件即可充分发挥.NET的强大功能。

Blazor 允许开发人员在桌面应用和移动应用中使用,Electron允许开发人员使用HTML和CSS构建桌面应用程序,Electron.Net是一种弥合差距并允许与Blazor一起使用的技术,微软已为本机移动应用程序建立了实验性绑定,这可能表明Blazor应用程序将在iOS和Android等平台上运行。

Blazor 功能特性

•使用C#代替JavaScript和TypeScript构建 Web UI•构建渐进式Web应用程序(PWA)•创建和使用用C#编写的可重用组件•在服务器端模式提供全面的调试支持,在客户端模式进行一些限制的调试•与HTML DOM的数据绑定(有限的双向绑定)•使用C#在客户端和服务器之间共享代码•可在所有现代网络浏览器(包括移动浏览器)中使用•Blazor代码具有与JavaScript相同的安全沙箱•使用JavaScript操作调用JavaScript框架和库•开源

什么是WebAssembly?

是基于堆栈的虚拟机的二进制指令格式, Wasm被设计为可移植目标,用于编译高级语言(如C / C ++ / Rust),从而可以在Web上为客户端和服务器应用程序进行部署。

本质上,它允许为Web浏览器编译代码。过去,诸如Adobe Flash或Microsoft Silverlight之类的技术通过强制用户安装插件来实现,现在不再需要这些,并且.NET运行时现在可以在WebAssembly上运行。

什么是React?

React是Facebook开源的一个JavaScript的UI框架,React并未尝试向开发人员提供构建现代Web应用程序所需的所有工具,相反,它专注于UI的主要方面,并允许开发人员方便的使用这些组件,这听起来也没啥,但事实并非如此,JavaScript UI库发展了这么多年,但React作为1号UI库,吸引了大量追随者,简单说,React主要是一个JavaScript库,但是可以轻松地与TypeScript一起使用。

React 功能特性

•使用JavaScript或TypeScript构建Web UI•构建渐进式Web应用程序(PWA)•可在所有现代网络浏览器(包括移动浏览器)中使用•大型的社区支持•开源•像VS Code这样的IDE中的全面调试支持

Blazor VS React

JavaScript对于C#开发人员而言具有难的学习曲线,并且不是静态类型的语言。许多团队负责人会遇到雇用后端和前端开发人员的问题。很难找到同时擅长JavaScript和C#的开发人员。如果Blazor是首选技术,则后端C#开发人员会掌握有关Blazor前端开发的知识。后端开发人员可以轻松切换角色来修复前端的错误,也可以熟练地构建前端应用程序。

Blazor尚未像React那样成熟,但是Microsoft会在该框架上建立基础,然后在SPA领域流行,客户端调试是缺少的主要功能,后边应该会支持。如果您的企业现在需要可用于生产的SPA并具有JavaScript专业知识,那么React将比Blazor更好的选择,但是,如果团队由C#开发人员组成并且SPA有发展的空间,请考虑使用Blazor。在这种情况下,Blazor有很大的机会随着时间的推移产生更多可维护的代码。

尽管对于静态类型的语言通常是否更好还存在一些争论,但是许多开发人员会说静态类型的语言对于大型项目而言更好。与JavaScript相比,C#可能成为更可取的选择。

什么是Angular?

Angular是由Google团队编写和维护的,一套基于TypeScript并且流行的Web和移动SPA框架。它与Angular不同的是,它是一个完整的框架。TypeScript是一种静态类型化语言,例如C#,并且可以转换为JavaScript。TypeScript和C#相似,因为Microsoft在维护它。Angular的更高版本也以类似于Blazor的方式支持服务器端渲染。模板语法与razor语法类,并且具有数据绑定的HTML DOM UI组件。

Web开发人员更熟悉Angular,因为它利用了现有的JavaScript框架,并且具有JavaScript背景。它拥有一个充满活力的成熟的社区。

Angular 功能特性

•使用TypeScript构建Web UI•构建渐进式Web应用程序(PWA)•使用HTML DOM进行双向数据绑定•可在所有现代网络浏览器(包括移动浏览器)中使用•大型的社区•开源•像VS Code这样的IDE中的全面调试支持•完整的内置API,可完成常见的应用程序任务

Blazor VS Angular

Angular也是一个成熟的框架,拥有庞大的社区,而Blazor则在不断发展。但是,Angular包含TypeScript范例,对于C#开发人员而言,它比JavaScript更自然地适应。Angular比React更全面,并且将自己宣传为框架而不是UI库。Angular不仅仅是UI组件。它鼓励开发人员开箱即用地使用组件,因此代码变得更加统一。

什么是Vue.js?

Vue与Angular具有相似的背景,开发人员使用JavaScript构建应用。它位于React和Angular之间,因为它在UI库和框架之间扩展。它是一个更精致的框架,但仍然是React和Angular的竞争对手。与React一样,开发人员可以使用TypeScript,但更多是 JavaScript。

Vue.js 功能特性

•使用JavaScript或TypeScript构建Web UI•构建渐进式Web应用程序(PWA)•使用HTML DOM进行双向数据绑定•可在所有现代网络浏览器(包括移动浏览器)中使用•中型的社区•开源•像VS Code这样的IDE中的全面调试支持•用于日常应用程序任务的全套内置API

Blazor VS Vue.js

Angular和React的许多比较点也适用于Vue.js。对于不仅仅需要UI库但又不需要完整的Angular框架的开发人员来说,Vus.js可能是一个折衷的折衷方案。Angular和Vue.js之间一些比较倾向于表明Vue.js在性能方面确实做到合理。因此,对于目前需要开发SPA的团队来说,Vue.js可能是另一个不错的选择,但是再次强调,将Blazor与C#结合使用对于具有C#背景的团队可能会产生更好的结果。

总结

现在,C#开发人员在构建UI时有很多选择。Blazor将熟悉的HTML DOM带入C#,并为Web开发人员提供了使用C#的能力。它具有构建桌面和移动应用程序的潜力,并在Microsoft开发社区中具有吸引力。在评估下一个SPA的技术时,你可以考虑使用 Blazor!

最后

欢迎扫码关注我们的公众号 【全球技术精选】,专注国外优秀博客的翻译和开源项目分享,也可以添加QQ群 897216102

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/305856.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言的使用比例远远高于python语言对吗_Python和C语言的语法有什么不同?

随着经济发发展,互联网精英的缺乏越来越严重了,尤其是编程工程师,市场缺乏率极高,所有对于准备即将学习编程朋友,是一个非常的好时机Python和C语言的语法有什么不同?python与C的区别如下:1、语言…

ASP.NET 應用程式的安全性模型

本單元內容 功能 ASP.NET 應用程式依賴於許多不同元素及技術的成功交互操作。每個方案元件都提供安全性功能,以滿足其自身的需求。然而,純粹從個別元件的角度考量安全性還不夠。若要提供整體方案的安全性,您還必須考量元件如何彼此互動。 本單…

.NET开源5年了,这些宝藏你还没get?

从2016年微软发布.NET Core1.0,至今.NET开源也快5年了,GitHub也涌现了很多优秀的开源项目,关于CLR层面调优的讨论也多了起来,尤其是龙芯.NET开源的CLR迁移项目,更是让.NET进入一个全新的时代。鲁迅说过:菜鸟…

java socket send_java socket编程

TcpServerServer端所要做的事情主要是建立一个通信的端点,然后等待客户端发送的请求。典型的处理步骤如下:1. 构建一个ServerSocket实例,指定本地的端口。这个socket就是用来监听指定端口的连接请求的。2. 调用socket的accept()方法来获得下面…

C#来创建和读取XML文档 [转]

C#来创建和读取XML文档【关键词】:XML 录入:小鱼之家 来源:http://fisher.xundain.com 时间:2005-3-3 23:41:54 点击:85次 扩展标记语言XML(eXtensible Markup Language)&#xff0…

如何成功搞垮一个团队?

阅读本文大概需要3分钟。最近好几个读者聊到是否能写一些怎么带团队的文章,在互联网职场中,升职带团队被大部分职场人视为职业生涯的重大转折点。一方面,升职意味着更丰厚的待遇,另一方面,带团队意味着自己大小变成了一…

Python学习第一天

干程序这行比较辛苦的就是要随时更新自己的知识。闷~~为了让自己能够更加深入的学习GUN和LINUX。在简单了解了shell以后决定学习Python。--------&#xff0d…

WinForm捕获全局异常(捕获未处理的异常)

背景我们在做WinForm程序的时候,一般都是对异常进行处理,但是,我们要防止不小心出现未知异常,导致软件崩溃。也可采集系统未知的异常信息,防止出现异常,也无法下手。于是就有了如这篇文章标题所述的一个简单…

it's so cold

今晚值日,本来中午不冷的,就换了衬衫,结果傍晚的时候就很凉,吃过晚饭只好回去换了件秋天的棉衫。但晚上我值日的那个地方风很大,熬了一节课,下课学生来打乒乓,借了件他们的校服穿,结…

java 继承 冒号_java继承(extends)简单介绍

继承相信很多人都有听说过,继承是面向对象的三个基本特征之一,下面的话就一起通过简单的文章来对java继承进行一下了解吧。继承和现实生活中的“继承”的相似之处是保留一些父辈的特性,从而减少代码冗余,提高程序运行效率。Java中…

如何在 ASP.NET Core 中写出更干净的 Controller

你可以遵循一些最佳实践来写出更干净的 Controller,一般我们称这种方法写出来的 Controller 为瘦Controller,瘦 Controller 的好处在于拥有更少的代码,更加单一的职责,也便于阅读和维护,而且随着时间的推移也容易做 Co…

探索 .NET团队对API的设计流程

原文作者:steve gordon 原文链接: https://www.stevejgordon.co.uk/how-are-dotnet-apis-designed在这篇文章中,我想介绍一些我觉得非常有趣的东西,.NET 团队是如何设计API的?我们先来看下.NET团队面临的有哪些挑战,您…

静态页面的值传递

1两窗口之间存在着关系.父窗口parent.htm打开子窗口son.htm子窗口可以通过window.opener指向父窗口.这样可以访问父窗口的对象. 优点:取值方便.只要window.opener指向父窗口,就可以访问所有对象. 不仅可以访问值,还可以访问父窗口的方法.值长度无限制.缺点:两窗口要存在着…

java类同步_Java中方法,对象,类的同步

关于在多线程环境中使用同步,我需要一些澄清.我在下面有一个小例子类.但我实际上发现很难做出以下内容如何工作的测试用例;我想要测试用例的原因是要了解同步如何处理这些不同的场景>如果一个线程调用SharedResource.staticMethod,它将获取该类的锁.它是否意味着一个SharedR…

ocelot 中间件的变化

ocelot 中间件的变化Intro之前我们使用 ocelot 的时候自定义了一些中间件来实现我们定制化的一些需求,最近博客园上有小伙伴问我怎么使用,他用的版本是 16.0 版本,16.0 和 17.0 版本的差异不是特别大,就以 17.0 版本为例看一下 oc…

mybatis mysql usegeneratedkeys_mybatis中useGeneratedKeys用法--插入数据库后获取主键值

前言:今天无意在mapper文件中看到useGeneratedKeys这个词,好奇就查了下,发现能解决我之前插入有外键表数据时,这个外键获取繁琐的问题,于是学习敲DEMO记录在项目中经常需要获取到插入数据的主键来保障后续操作&#xf…

Istio 知多少 | 下一代微服务的守护者

1. 引言在写完eShopOnContainers 知多少[12]:Envoy gateways后,就一直想进一步探索Service Mesh,最近刚在极客时间上学完《Service Mesh入门》,又大致浏览了一遍官方文档,对Istio也算有了基本的认识。下面就根据自己的…

微软家也会出错

下图是2006年2月8日微软WebCast首页的截图转载于:https://www.cnblogs.com/mssite/archive/2006/02/08/327130.html

mysql 基础视图_MySQL基础(4) | 视图

MySQL基础(4) | 视图基本语法1.创建CREATE VIEW AS 语法说明如下。:指定视图的名称。该名称在数据库中必须是唯一的,不能与其他表或视图同名。:指定创建视图的 SELECT 语句,可用于查询多个基础表或源视图。对于创建视图中的 SELEC…

C# 中的 null 包容运算符 “!” —— 概念、由来、用法和注意事项

在 2020 年的最后一天,博客园发起了一个开源项目:基于 .NET 的博客引擎 fluss,我抽空把源码下载下来看了下,发现在属性的定义中,有很多地方都用到了 null!,如下图所示:这是什么用法呢&#xff1…