Blazor带我重玩前端(三)

VS自带的Blazor模板介绍

需要升级VS2019以及.NET Core到最新版(具体的最低支持,我已经忘了,总是越新支持的就越好),以更好的支持自己开发Blazor项目。

使用VS创建Blazor WebAssembly项目

  • 搜索Blazor模板

  • 选择Blazor WebAssembly App模板

  • 项目实例

  • 项目实例

  1. BlazorApp.Shared:提供最一般的支持,包括各个Model

  2. BlazorApp.Client:依赖BlazorApp.Shared,该项目侧重于Pages功能

  3. BlazorApp.Server:依赖BlazorApp.Shared、BlazorApp.Client,该项目侧重于提供接口功能

BlazorApp.Client

项目结构

从上图可知 该项目主要包括wwwroot、Pages、Shared三个文件夹,以及_Imports.razor、App.razor、Program.cs这三个单独的文件。

wwwroot

这个文件夹和我们ASP.NET Core MVC里的wwwroot基本一致,不过需要注意的是,这个文件夹里面有一个比较重要的文件index.html,它是我们Blazor项目的起点。这个文件里也引用了blazor.webassembly.js,可是我们在项目中没有看到。这没关系,因为它会由Microsoft.AspNetCore.Components.WebAssembly.Build提供,在运行编译的时候会自己出现的。

Shared

这个文件夹里,有三个文件,分别是MainLayout.razor、NavMenu.razor、SurveyPrompt.razor。

  • MainLayout是Layout文件,它定义了该项目的基本布局

  • NavMenu是Component,它实现了菜单功能,并对外提供了独立而又单一的组件功能

  • SurveyPrompt也是Component,它实现了文件传入与连接跳转功能,对外也是提供了独立而又单一的菜单功能,同时这也是一个带参的组件 组件功能后续会详细介绍,但是需要提前说明的是,任何组件一经对外使用,都是独立而又单一的。接下来看一下运行后的效果图:整体的风格、左侧的菜单、右侧的链接都像我们展示了布局和组件功能

Pages

里面定义了三个.razor文件,这也是模板提供给我的Blazor编写案例

  • Index.razor向我们展示了,组件的调用

  • FetchData.razor向我们展示了Call远程API和路由功能(@page "/fetchdata")

  • Counter.razor向我们展示了事件调用

其他文件

  • _Imports.razor,这个文件和我们在ASP.NET Core项目中的_Imports.cshtml文件,没有什么区别

  • App.razor,这是根组件,里面定义了路由功能、默认布局、以及404展示

  • Program.cs 在职能上和我们ASP.NET Core项目的Program.cs文件也没有什么区别,但是里面定义了Http所要调用的EndPoint(builder.Services.AddTransient(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) });)

运行项目

设置BlazorApp.Server为启动项目

  1. 下载必须文件如图所示,我们需要加载6.15M的文件,同时可以看到Blazor的运行时信息mono_wasm_runtime_ready。

  2. 接下来,我们展开Object来看看其详细信息,会看到Object中有太多的依赖程序集。

  3. 打开源代码tab页,会看到以下几个文件

  • dotnet.wasm文件,打开后,会看到我们前文说过的WebAssembly文本格式的内容。

  • blazor.webassembly.js,用于下载.NET运行时,依赖程序集等,同时还会初始化运行应用的程序集

  • dotnet.3.2.0.js也是我们之前所说的用于调用C#方法的JS文件

添加页面

这个比较简单,如下操作即可接下来的内容我们将以此模板为例,进行展开讨论

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

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

相关文章

[mybatis]Configuration XML_environments

enviroments transactionManager There are two TransactionManager types (i.e. type"[JDBC|MANAGED]") that are included with MyBatis: • JDBC – This configuration simply makes use of the JDBC commit and rollback facilities directly. It relies on the…

Mediator(中介者)--对象行为型模式

Mediator(中介者)–对象行为型模式 一、意图 用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。 二、动机 1.在软件构建过程中,经常…

[mybatis]Configuration XML_mappers

mappers 将sql映射注册到全局配置中 mapper 注册一个sql映射 resource:引用类路径下的sql映射文件url:引用网络路径或者磁盘路径下的sql映射文件class:引用(注册)接口 1.有sql映射文件,映射文件名必须和接口同名,并且放在与接口同一目录下;…

Memento(备忘录)--对象行为型模式

Memento(备忘录)–对象行为型模式 一、意图 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保持这个状态。这样以后就可将该对象恢复到原先保存的状态。 二、动机 1.在软件构建过程中,某些对象的状态…

IBM、甲骨文、CNCF 就谷歌对 Istio 治理的处理提出抗议

近日来 Istio 商标转让、IBM 抗议谷歌违背承诺未将 Istio 捐献给 CNCF 的事情闹的沸沸扬扬。Google 宣布将 Istio 商标转让给 Open Usage Commons 组织IBM 声明对 Google 违背承诺未将 Istio 贡献给 CNCF 表示失望下面是据 TheRegister 的报道:谷歌创建了一个开放使…

Observer(观察者)--对象行为型模式

Observer(观察者)–对象行为型模式 一、意图 定义对象间的一种一对多的依赖关系,当一个对象的状态发生变化时,所有的依赖于它的对象都得到通知并被自动更新。 二、动机 1.在软件构建过程中,我们需要为某些对象建立一…

【今天下午活动】从 HelloWorld 到 AntDesign,Blazor 将 .NET 带到现代前端圈

Blazor 是一个 Web UI 框架,可通过 WebAssembly 在任意浏览器中运行 .Net 。Blazor 旨在简化快速的单页面 .Net 浏览器应用的构建过程,它虽然使用了诸如 CSS 和 HTML 之类的 Web 技术,但它使用 C#语言和 Razor 语法代替 JavaScrip…

[mybatis]sqlSessionFactory.openSession()

第一个是不会自动提交的 第二个带参数的是会自动提交的

State(状态)--对象行为型模式

State(状态)–对象行为型模式 一、意图 允许一个对象在其内部状态改变时改变它的行为。对象看起来似乎修改了它的类。 二、动机 1.在软件构建过程中,某些对象的状态如果改变,其行为也会随之而发生变化,比如文档处于只…

推荐一个Asp.Net Core工具库

Masuit.Tools开源地址https://github.com/XiLife-OSPC/Masuit.Tools包含一些常用的操作类,大都是静态类,加密解密,反射操作,硬件信息,字符串扩展方法,日期时间扩展操作,大文件拷贝,图…

Strategy(策略)--对象行为型模式

Strategy(策略)–对象行为型模式 一、意图 定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。 二、动机 1.在软件构建过程中,某些对象使用的算法可能多种多…

12个Visual Studio调试效率技巧

在这篇文章中,我们假定读者了解VS基本的调试知识,如:F5 开始使用调试器运行程序F9 在当前行设置断点F10 运行到下一个断点处F5 从被调试的已停止程序恢复执行F11 步进到函数内(如果当前程序指针指向一个函数)F10 步过函…

Template Method(模板方法)--类行为型模式

Template Method(模板方法)–类行为型模式 一、意图 定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。TemplateMethod使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。 二、动机 1.在软件构建过程中,对…

骚年快答 | 微服务架构中的BFF到底是啥?

【答疑解惑】| 作者 / Edison Zhou这是恰童鞋骚年的第263篇原创内容昨天的骚年快答《技术中台与业务中台都是啥玩意》一文中留下一个问题:BFF是啥?为啥在API网关和业务中台之间加入了一层BFF?考虑到在实际工作中,我的大部分同事都…

Visitor(访问者)--对象行为型模式

Visitor(访问者)–对象行为型模式 一、意图 表示一个作用于某个对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。 二、动机 1.在软件构建过程中,由于需求的改变,某些类层次结构中常…

骚年快答 | 技术中台与业务中台都是啥?

【答疑解惑】| 作者 / Edison Zhou这是恰童鞋骚年的第262篇原创内容最近有童鞋在我之前发布的《聊聊中台》一文中提问:技术中台是什么?和业务中台又有什么区别?考虑到在工作中,也有部分同事问过这个问题,我这里总结一下…

[mybatis]映射文件_参数处理_#和$取值区别

#{}:可以获取map中的值或者pojo对象属性的值${}:可以获取map中的值或者pojo对象属性的值 区别: #{}:是以预编译的形式,将参数设置到sql语句中,相当于原生jdbc的PreparedStatement;防止sql注入${…

平台or职位,你怎么选?

这里是Z哥的个人公众号每周五11:45 按时送达当然了,也会时不时加个餐~我的第「150」篇原创敬上大家好,我是Z哥。这周有位小伙伴和我聊到一个问题,选择工作的时候是平台重要还是职位重要?我想,很…

闲谈设计模式

闲谈设计模式Intro设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。了解这些前辈们总结出来的经验有助于帮助你写出来更优秀的代码,帮助你写出可扩展、可读、可维护的高质量代码。在极客时间里推出…

[mybatis]log4j

引入依赖&#xff1a; <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>在资源文件下写一个log4j配置文件: <?xml version"1.0" encoding"UT…