Blazor入门

NOW

Blazor是一个基于C#, RazorHTML的新的Web UI框架。它通过WebAssembly运行在浏览器中。有利于使用C#而不是JavaScript构建交互式的Web UI。这篇文章演示了如何使用Blazor构建SPA应用。Blazor简化了可在任何浏览器中运行的快速且美观的SPA的任务。它通过使开发人员能够编写基于Dotnet的Web应用程序来实现此目的。这些应用程序可以在使用了开放Web标准的浏览器中运行。让我们开始使用Blazor吧。在这篇文章中,我们将讨论一下内容:

  • 主机模型

  • 启用身份验证和授权

  • 深入了解默认Blazor页面

前期准备

  • Visual Sudtion 2019

  • Install .NET Core 3.1

  • 安装Blazor项目模版

主机模型(Hosting models)

你有两种选择来托管应用程序。首先,在服务器端使用Razor组件,接下来,在浏览器中将应用程序作为Web Assembly运行。

服务器端

支持在 ASP.NETCore 应用程序的服务器上托管 Razor组件。用户交互将通过 SignalR连接和处理。

客户端

Blazor应用程序以及.NET运行时和其他依赖项已下载到浏览器中。另外,你可以在客户端和服务器端之间共享模型、验证和其他业务逻辑。此外,你还可以利用在浏览器上直接运行的几个.NET 库。

显然,每个模型都有其自身的优缺点。特别是它们大多数与依赖性,性能,浏览器兼容性等有关。选择其中的一种实现方法依赖于你的决定。在本文中,我们将以一个示例讨论服务器端托管。但是,这个决定不是这篇文章的主要目的。

开始使用

首先,在创建新项目时搜索“Blazor”,然后选择“Blazor 应用”。

点击“下一步”,在出现的页面上输入项目名称,并选择适当的项目存储的位置。

在下一页上,选择要创建的应用程序的类型。为此,在这篇文章中,我将创建一个“Blazor Server 应用”的应用程序。

在创建项目之前,点击“身份验证”部分下面的“更改”链接。选择“个人用户账户(I)”,并在右侧的下拉选项中选择“存储应用内的用户账户”。其他可用的选项包括:“不进行身份验证”、“工作或学校账户”和“Windows 身份验证”。点击“确定”按钮之后,点击“创建”按钮实现项目的创建工作。项目创建完成后,可以从项目的属性页(“调试”选项卡)禁用HTTPS。

现在,我们创建了启用身份验证的Blazor项目,运行项目后,可以看到以下界面。

了解项目结构

该项目的结构与MVC应用程序的结构相似,你可以在项目中看到 Areasappsetting.jsonProgram.csStartup.cs。除此之外,你还可以看到带 razor扩展名的文件,这些文件特定于“Blazor”。让我们详细的看一下。

  • Identity — 这个文件夹被创建是因为我们在创建项目时选择了身份验证方法。它具有“AuthenticationStateProvider”类和用于登录和注销的HTML文件。

  • Data — 项目创建时,默认情况下会提供与Entity Framework相关的nuget软件包。这个文件夹包含一个迁移文件,用于创建和身份验证相关的表,例如用户,角色等。此外,它还包含“DBContext”文件,模型和服务。该服务获取默认演示页面的天气预报详细信息。

  • Pages — 如果你是.NET 开发人员,可能听说过Razor。Blazor应用程序基于组件。组件是可重用的构建块。它可以是单个控件,也可以是具有多个控件的块。这些组件以 Razor标记编写。但是Blazor的上下文中, Razor的主要区别在于,它是基于UI 逻辑构建的,而不是基于请求/ 响应传递的。

启用身份验证和授权

要启用身份验证,请执行一下步骤。

  • 创建存储用户和角色详细的表

  • 添加用户和角色

  • 实施授权

创建表

执行 EntityFrameworkupdate-database命令进行创建表。默认情况下,应用程序在 localdb中创建数据库。或者,你可以根据需要在 appsetting.json中修改连接字符串。默认迁移会创建于身份验证相关的表,例如 AspNetUsersAspNetRoles等。具体操作为:选择 工具-> Nuget包管理器-> 程序包管理器控制台。在界面上输入 update-database

用户注册

第一种选择是使用注册界面,这将有助于将用户添加到系统中。

public void ConfigureServices(IServiceCollection services)
{services.AddDbContext<ApplicationDbContext>(options =>options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));services.AddDefaultIdentity<IdentityUser>(options =>{options.Password.RequireNonAlphanumeric = false;options.Password.RequireLowercase = false;options.Password.RequireUppercase = false;options.Password.RequireDigit = false;options.SignIn.RequireConfirmedAccount = true;}).AddEntityFrameworkStores<ApplicationDbContext>();services.AddRazorPages();services.AddServerSideBlazor();services.AddScoped<AuthenticationStateProvider, RevalidatingIdentityAuthenticationStateProvider<IdentityUser>>();services.AddSingleton<WeatherForecastService>();
}

实施授权

现在我们已经创建了表,添加了用户和角色。让我们启用页面授权。Blazor具有用于授权目的的 AuthorizeView组件。此组件根据授权状态进行显示内容。如果页面内容位于 AuthorizeView中,则只有授权用户才能看到它。修改 Counter.razor页面内容。

<AuthorizeView><h1>Counter</h1><p>Current count: @currentCount</p><button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
</AuthorizeView>

如果你需要为授权和未授权用户显示不同的内容怎么办?你可以在 AuthorizeView中使用 AuthorizedNotAuthorized元素,这有助于根据授权状态提供不同的内容。

<AuthorizeView><Authorized><h1>Counter</h1><p>Current count: @currentCount</p><button class="btn btn-primary" @onclick="IncrementCount">Click me</button></Authorized><NotAuthorized>You are not authorized to view this page!</NotAuthorized>
</AuthorizeView>

深入探索 Blazor页面

让我们分析 razor组件,并尝试了解它的基本组成部分。我将使用 FetchData.razor进行介绍。

@page "/fetchdata"
@using BlazorServerApp.Data
@inject WeatherForecastService ForecastService
<h1>Weather forecast</h1>
<p>This component demonstrates fetching data from a service.</p>
@if (forecasts == null)
{<p><em>Loading...</em></p>
}
else
{<table class="table"><thead><tr><th>Date</th><th>Temp. (C)</th><th>Temp. (F)</th><th>Summary</th></tr></thead><tbody>@foreach (var forecast in forecasts){<tr><td>@forecast.Date.ToShortDateString()</td><td>@forecast.TemperatureC</td><td>@forecast.TemperatureF</td><td>@forecast.Summary</td></tr>}</tbody></table>
}
@code {private WeatherForecast[] forecasts;protected override async Task OnInitializedAsync(){forecasts = await ForecastService.GetForecastAsync(DateTime.Now);}
}

@page - 使用 @page属性设置组件中的 route属性。这指定组件的路由端点。一个组件可以通过具有多个 @page指令来具有多个路由属性。

@inject - 你可以使用 @inject属性将服务注入组件。在该示例中, WeatherForecastService已注入,以用于检索数据。你可以通过 Startup.cs中注册他们来使用服务。该服务类似于 ASP.NET CORE MVC

@code - 该块包含用于渲染和事件处理的代码。它可以像方法的变量声明一样。有一个类似于 @code的东西, @function具有相同的功能。从 ASP.NET CORE3.0开始,建议使用 @code,而不是 @function

总结

简而言之,本文试图介绍 Blazor,以及如何使用 Blazor创建你的第一个应用程序。除此之外,我们还讨论了托管模型,身份验证,授权的实现以及默认页面中使用的指令。

下一步工作

除了此篇文章外,我还计划写其他几篇文章:

  • 使用 Blazor和 EntityFrameworkCore进行CRUD操作

  • Blazor中模型验证

  • Blazor应用程序的容器化

  • Blazor的路由

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

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

相关文章

第七届蓝桥杯(国赛)——随意组合-dfs,next_permutation

【问题描述】 小明被绑架到X星球的巫师W那里。 其时&#xff0c;W正在玩弄两组数据 (2 3 5 8) 和 (1 4 6 7) 他命令小明从一组数据中分别取数与另一组中的数配对&#xff0c;共配成4对&#xff08;组中的每个数必被用到&#xff09;。 小明的配法是&#xff1a;{(8,7),(5,6),(…

方框加对勾怎么输入_对号“√”怎么输入到方框“□”-空格对号

对号”√”怎么输入到方框”□”内啊&#xff1f;&#xff1f;是这样的&#xff0c;我在做一个表格例如&#xff1a;1&#xff0c;是否完成。□2&#xff0c;是否已经准备好资料。□如果“是”就在方框内打对号“√”&#xff0c;不是就打错号“X”但是怎么打在方框内阿&#x…

C#桌面开发的未来WebWindow

WebWindowWebWindow是跨平台的库。Web Window的当前实验实现可在以下平台上运行&#xff1a;Windows – 需要基于Chromium的EdgeLinux – 使用WebKitMac – 需要Safari源码https://github.com/SteveSandersonMS/WebWindow.gitZeje Fork的分支&#xff1a;https://github.com/ze…

第七届蓝桥杯决赛真题 - 凑平方数-全排列+dfs+set去重

题目&#xff1a; 凑平方数 把0~9这10个数字&#xff0c;分成多个组&#xff0c;每个组恰好是一个平方数&#xff0c;这是能够 办到的。比如&#xff1a;0, 36, 5948721再比如&#xff1a; 1098524736 1, 25, 6390784 0, 4, 289, 15376 等等…注意&#xff0c;0可以作为独立的…

计算标准差分母是n还是n-1?

概述 提问&#xff1a;在我们计算某些数据标准差&#xff08;或者方差&#xff09;的时候&#xff0c;会发现有些公式分母是n&#xff0c;而有些公式的分母却是&#xff08;n-1&#xff09;&#xff0c;那么到底哪个公式才是正确的呢&#xff1f; 答案&#xff1a; 如果是算…

三调 图斑地类面积_三调对于最小上图图斑面积的要求是:

【单选题】设二维数组 A[1...m,1...n] (即 m 行 n 列)按行存储在 B[1...m*n] 中,则二维数组元素 A[i,j] 在一位数组 B 中的下标为( )【单选题】二维数组 a[1..N , 1..N] 可以按行存储或按列存储。对于数组元素 a[i,j] ( 1<i,j<N ),当( )时,在按行和按列两种存储方式下,其…

C#小游戏—钢铁侠VS太空侵略者

身为漫威迷&#xff0c;最近又把《钢铁侠》和《复仇者联盟》系列又重温了一遍&#xff0c;真的是印证了那句话&#xff1a;“读书百遍&#xff0c;其意自现”。看电影一个道理&#xff0c;每看一遍&#xff0c;都有不懂的感受~ 不知道大伙是不是也有同样的感受&#xff0c;对于…

受检异常 非受检异常_这样设计 Java 异常更优雅,赶紧学

来源&#xff1a;Lrwinlrwinx.github.io/2016/04/28/如何优雅的设计java异常/导语异常处理是程序开发中必不可少操作之一&#xff0c;但如何正确优雅的对异常进行处理确是一门学问&#xff0c;笔者根据自己的开发经验来谈一谈我是如何对异常进行处理的。由于本文只作一些经验之…

[蓝桥杯][2018年第九届真题]调手表-bfs

小明买了块高端大气上档次的电子手表&#xff0c;他正准备调时间呢。在 M78 星云&#xff0c;时间的计量单位和地球上不同&#xff0c;M78 星云的一个小时有 n 分钟。大家都知道&#xff0c;手表只有一个按钮可以把当前的数加一。在调分钟的时候&#xff0c;如果当前显示的数是…

.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(上)...

23 | 静态文件中间件&#xff1a;前后端分离开发合并部署骚操作我们先来看一下静态文件中间件有哪些能力1、支持指定相对路径2、支持目录的浏览3、支持设置默认文档4、支持多目录映射源码链接&#xff1a;https://github.com/witskeeper/geektime/tree/master/samples/StaticFi…

src获取同级目录中的图片_一个简单的Python爬虫实例:百度贴吧页面下载图片

本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。1. 概述本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。下载图片的步骤如下&#xff1a;获取网页html文本内容&#xff1b;分析html中图片的html标签特征&#xff0c;用正…

C++并查集的实现

编号代表每一个元素。数组par表示的是父亲的编号&#xff0c;也就是前驱。par[x] x时&#xff0c;x是所在的树的根。 代码如下&#xff1a; #include <iostream> using namespace std; const int N 100010; int par[N], ranks[N];void init(int n) { //初始化n个元素…

十问十答 Apache 许可证

Apache 许可证由 Apache Software Foundation&#xff08;ASF&#xff09;发行&#xff0c;是一个由强大社区支持的流行的被广泛部署的许可证。Apache 许可证允许你自由地使用、修改和分发任何 Apache 许可的产品&#xff0c;前提是遵循 Apache 许可的条款。01Apache 许可证的条…

(一)基于企业现金流预测的投资决策-项目介绍

项目背景 某企业想提高现金流的利用率,以便产生更大的投资收益。遇到的问题是:何如在保证更多的资金流向高收益投资的同时,不出现资金短缺的问题。 确定可用于投资的金额 Step1 预测未来的收入、支出和余额 潜在逻辑: 现金流 = 收入 - 支出当月余额(资金存量)= 上月余…

连续不等_第九讲 函数的连续性与函数的间断点

写在前面的话&#xff1a;本讲主要内容讲了连续性的定义&#xff0c;及其三个衍生的表述方式&#xff0c;函数的几类间断点。最后一个例题回顾了极限的保号性&#xff0c;是不是又有点生疏了&#xff1f;没关系&#xff0c;回过头再看看。反复研读&#xff0c;用心体会。如果有…

[蓝桥杯2015决赛]分机号-枚举(水题)

题目描述 X老板脾气古怪&#xff0c;他们公司的电话分机号都是3位数&#xff0c;老板规定&#xff0c;所有号码必须是降序排列&#xff0c;且不能有重复的数位。 比如&#xff1a;751,520,321 都满足要求&#xff0c;而766,918,201 就不符合要求。 现在请你计算一下&#xff0c…

应用程序使用统计信息 – .NET CORE(C#) WPF界面设计

本文首发地址&#xff1a;https://dotnet9.com/10546.html关键功能点抽屉式菜单圆形进度条Demo演示&#xff1a;1. 新建项目使用 VS 2019 的 .NET Core 3.1 WPF 项目模板&#xff0c;创建名为 “MobileAppUsageDashboardCore” 的项目&#xff0c;NuGet 引入 MaterialDesign 的…

正态分布-区间估计之单侧和双侧

区别 很简单,正态分布都是左右对称的&#xff0e;在左测就是的分位点是α/2,右侧是1-α/2&#xff0e; 假设一&#xff1a;双侧假设,拒绝区域在两边而且两边对称,在题目问你”是否相等?”的时候用 H0:μ&#xff1d;μ0,H1:μ≠μ0,拒绝区域&#xff1a;u的绝对值大于u1-α/…

iso qemu 安装ubuntu_基于libvirt 和QEMU在macOS安装Ubuntu

在流行的虚拟架构体系中&#xff0c;最重要的技术当然要数libvirt和QEMU了。包括Linux虚拟化技术中KVM和xen都使用了QEMU。关于Xen和KVM进行虚拟化&#xff0c;以及在Window下使用Vmware&#xff0c;VirtualBox和hyper-v构建虚拟机&#xff0c;可能大家都有过很多的尝试。今天我…

[蓝桥杯2017初赛]等差素数列-巧妙枚举(思维)

题目描述 2,3,5,7,11,13,…是素数序列。 类似&#xff1a;7,37,67,97,127,157 这样全由素数组成的等差数列&#xff0c;叫等差素数数列。 上边的数列公差为30&#xff0c;长度为6。 2004年&#xff0c;格林与华人陶哲轩合作证明了&#xff1a;存在任意长度的素数等差数列。 这是…