asp.net Core blazor学习笔记

news2024/11/13 7:57:14

最近在研究学习blazor,为了加深记忆,手动记录一下,以下内容为个人理解记录,仅供参考:

Blazor开发学习

  • 一 分类
    • 1 Blazor Server 应用
    • 2 Blazor WebAssembly 应用
    • 3 Blazor Hybrid 应用和 .NET MAUI
  • 二 基础知识
    • 1 路由
    • 2 组件库的使用
      • 2.1 组件库修饰
      • 2.2 对组件进行分组
      • 2.3 组件继承
      • 2.4级联参数的使用
      • 2.5 新建blazor项目,自带的图标
      • 2.6 动态切换组件显示
      • 2.7 系统配置信息
      • 2.7 内置组件使用
      • 2.8 弹出框组件使用
      • 2.9 支持的 EventArgs 显示在下表中
      • 2.10 延时控制组件
    • 3 注意
      • 3.1 设置打开的第一个界面
      • 3.2 IIS部署
    • 4 涨知识

一 分类

1 Blazor Server 应用

2 Blazor WebAssembly 应用

速度略慢,使用AOT编译可以提供速度,相应的应用会变大。

3 Blazor Hybrid 应用和 .NET MAUI

WPF开发,Windows桌面应用开发及移动设备应用开发。

二 基础知识

1 路由

@page “路由名称(小写字母、横线)”,可以写多个路由

2 组件库的使用

2.1 组件库修饰

若要对组件添加css样式,可创建“组件.razor.css”

2.2 对组件进行分组

使用组件时,添加上分组文件夹即可。

2.3 组件继承

关键字:@inherits 可使用继承组件的属性和方法

2.4级联参数的使用

使用CascadingValue向子组件传递数据,多个级联参数,需要Name属性相关联

//父组件
<CascadingValue Value="@isShowTips" Name="isShowTips">
	<CascadingValue Value="@tipPosition" Name="tipPosition">
		<KpComponents.BaseComponents.DlgTips DlgClass="tip-near" TrangleClass="tip-trangle-top" Content="数据归属机构:当前账户所属机构在为哪个机构工作,最终数据归当前机构所有" />
	</CascadingValue>
</CascadingValue>

@code{
	private bool isShowTips = false;  //是否显示提示框
	private string tipPosition;
}

//子组件
	/// <summary>
    /// 是否进行显示
    /// </summary>
    [CascadingParameter(Name= "isShowTips")]
    public bool isShowTips { get; set; }
    
    /// <summary>
    /// 组件位置信息
    /// </summary>
    [CascadingParameter(Name= "tipPosition")]
    public string tipPosition { get; set; }

2.5 新建blazor项目,自带的图标

请添加图片描述
请添加图片描述

2.6 动态切换组件显示

<DynamicComponent Type="组件的命名空间" />

2.7 系统配置信息

系统配置信息在:wwwroot/appsettings.json
使用方式:

//JSON文件
{
  "h1FontSize": "50px"
}
//组件使用
@page "/configuration-example"
@using Microsoft.Extensions.Configuration
@inject IConfiguration Configuration   //将 IConfiguration 实例注入到组件中来访问配置数据

<h1 style="font-size:@Configuration["h1FontSize"]">
    Configuration example
</h1>

2.7 内置组件使用

PageTitle 用以设置导航栏显示的名称

2.8 弹出框组件使用

没有内置组件,可以使用第三方组件:
请添加图片描述
在Program.cs中进行组件注册:

builder.Services.AddBlazoredModal();

在wwwroot的index.html中引入相关js和css文件:

<link href="_content/Blazored.Modal/blazored-modal.css" rel="stylesheet" />
<script src="_content/Blazored.Modal/blazored.modal.js"></script>

根据需要引入命名空间

@using Blazored.Modal
@using Blazored.Modal.Services

使用方式

[Inject] 
protected IModalService ModalService { get; set; }

/// <summary>
/// 方法参数:
///string title:弹出框标题
///ModalParameters parameters:组件参数Dictionary<string, object>
///ModalOptions options:可以控制位置、弹出方式等信息
/// </summary>
ModalService.Show<组件>(方法参数);

2.9 支持的 EventArgs 显示在下表中

请添加图片描述
请添加图片描述

2.10 延时控制组件

	private async Task ShowTips(MouseEventArgs e)      //注意使用async  Task
	{
		tipPosition = $"top:{e.PageY + 5}px;left:{e.PageX-260}px;";
		isShowTips = true;
		await Task.Delay(3000);     //延时时间设置
		isShowTips = false;
	}

3 注意

3.1 设置打开的第一个界面

项目配置打开的首个Razor界面,需要在App.razor中进行配置:
请添加图片描述
注意打开的第一个Razor界面需要:

@inherits LayoutComponentBase

否则界面无法正常显示。

3.2 IIS部署

使用VS工具发布之后,生成的文件内容如下:
在这里插入图片描述
使用IIS无托管部署之后,需要安装:rewrite_amd64_zh-CN
https://www.iis.net/downloads/microsoft/url-rewrite#additionalDownloads

4 涨知识

<link rel="icon" href="images/Mylogo.ico" />  //用以设置标题栏图标

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

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

相关文章

使用预训练的 ONNX 格式的 YOLOv8n 模型进行目标检测,并在图像上绘制检测结果

目录 __init__方法&#xff1a; pre_process方法&#xff1a; run方法&#xff1a; filter_boxes方法&#xff1a; view_img方法&#xff1a; ​​​​​​​__init__方法&#xff1a; 初始化类的实例时&#xff0c;创建一个onnxruntime的推理会话&#xff0c;加载名为yolo…

电机启动对单片机重启的影响

单片机使用ASM1117对9V电压降压供电&#xff0c;IO口接三极管控制电机 &#xff0c;接9V&#xff1b;每次启动瞬间&#xff0c;单片机重启 试进行分析 网上参考&#xff0c;添加滤波&#xff0c;电容&#xff0c;阻容&#xff1b;分开电源处理&#xff08;双电源&#xff09;&…

JVM虚拟机(二)如何定位垃圾、判断对象是否死亡?垃圾回收算法、垃圾回收器、CMS、G1垃圾回收器

一、GC基本信息 1.1 什么是GC&#xff0c;垃圾回收&#xff1f; JVM的垃圾回收&#xff08;Garbage Collection&#xff0c;GC&#xff09;是一种自动内存管理机制&#xff0c;其主要目的是识别并清除不再使用的对象&#xff0c;释放内存空间以供应用程序中的其他部分使用。G…

go+gin+vue入门

后端框架 1、安装go、goland 2、创建空项目 3、下载要用的包&#xff1a;命令行输入go get -u github.com/xxxx 4、安装mysql数据库&#xff0c;使用navicat创建数据库。 5、按照项目框架搭建目录、文件、代码&#xff1a;如router、model… 6、运行测试&#xff0c;go run ma…

C语言基础(十一)

1、指针&#xff1a; C语言中的指针是一种非常重要的数据类型&#xff0c;可以直接访问和操作内存地址。指针存储变量的内存地址&#xff0c;而不是变量的值本身。通过使用指针&#xff0c;可以灵活地控制数据的存储和访问&#xff0c;实现复杂的数据结构如链表、树。 定义指…

C++操作excel,即使函数设置了不备份,但保存后,excel依然会自动生成备份文件的原因分析,及如何来禁止自动备份

开发环境 操作系统&#xff1a;windows 10 编译器&#xff1a;Visual Studio 2010、2015、2017、2022 office 2016、2019、2021 wps 2019、2024 问题描述 通过C操作excel&#xff0c;保存后&#xff0c;excel会自动生成备份文件。 void CExcelDemoDlg::OnBnClickedButton1() …

Open3D mesh 隐藏点移除

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.2完整代码 三、实现效果 3.1原始点云 3.2去除隐藏点后的点云 Open3D点云算法汇总及实战案例汇总的目录地址&#xff1a; Open3D点云算法与点云深度学习案例汇总&#xff08;长期更新&…

力扣 128. 最长连续序列

题目描述 我的思路 我的思路比较暴力&#xff0c;就是首先将数组从小到大进行排序&#xff0c;然后再依次遍历判断序列是否连续并时时更新连续序列的最长长度。比如示例1&#xff1a;nums [100, 4, 200, 1, 3, 2]&#xff0c;第一步先将数组进行排序得到sort_nums [1, 2, 3,…

Android Studio(3) 使用 Kotlin DSL和 Gradle 8.7 打包远程库到 AAR 的自定义方法

背景介绍 在 Gradle 7.3 及更早版本中,通常使用 com.kezong.fat-aar 插件来打包远程库到 AAR 中,随着 Gradle 的不断升级,尤其是到 8.7 版本后,Kotlin DSL开发逐渐成为主流,fat-aar 社区没有更新,插件的兼容性问题逐渐显现。我探索一种新的自定义方法,能够在 Kotlin DS…

js逆向学习

目前本人大三下&#xff0c;想要学习js逆向同学的可以联系我&#xff1a;2697279763qq.com 上面是本人做的一些比较复杂的项目&#xff0c;还有很多简单的项目&#xff0c;这里给出图片。 还有一些简单的js逆向。 教你各种补充环境&#xff0c;各种js算法&#xff0c;教你各种底…

(软工) 四代软件架构

&#x1f522;前言 当今软件架构中&#xff0c;拥有四代软件架构。这四个都是基于所在时代&#xff0c;技术&#xff0c;需求等多种因素应运而生的。 在未来是否会有第五代软件架构&#xff0c;无人可知。笔者大胆推测&#xff0c;这第五代很可能与人工智能的大语言模型有关&…

Windows—UDP编程

Client骨架&#xff1a; #include <iostream> #include <WinSock2.h> #pragma comment(lib,"ws2_32.lib")int main() {//启动Winsock DLLWORD wVersionRequested MAKEWORD(2, 2);WSADATA lpWSAData;WSAStartup(wVersionRequested, &lpWSAData);//…

【数据结构】线性表的顺序表示(顺序表的定义和基本操作)

计算机考研408-数据结构笔记本之——第二章 线性表 2.2 线性表的顺序表示&#xff08;顺序表的定义和基本操作&#xff1a;初始化/插入/删除/查找&#xff09; 2.2.1 顺序表的定义 1.定义 顺序表是线性表的顺序存储。 所谓顺序存储&#xff0c;就是把逻辑上相邻的元素存储在物…

预约咨询小程序搭建开发,uniapp前端,PHP语言开发

目录 前言&#xff1a; 一、预约小程序搭建功能介绍 二、示例代码片段 前言&#xff1a; 预约咨询小程序适合需付费咨询和交流的场景&#xff1a;比如讲师,摄影,婚庆&#xff0c;美发,律师,心理等等支持商家入驻支持视频、图文、线下、电话等方式在线支付咨询。 一、预约小程…

代码随想录 刷题记录-14 回溯(3)字符串、子集、排列问题

字符串 1.131.分割回文串 思路 本题这涉及到两个关键问题&#xff1a; 切割问题&#xff0c;有不同的切割方式判断回文 切割问题&#xff0c;也可以抽象为一棵树形结构&#xff0c;如图&#xff1a; 回溯三部曲 递归函数参数 全局变量数组path存放切割后回文的子串&…

《计算机操作系统》(第4版)第5章 虚拟存储器 复习笔记

第5章 虚拟存储器 一 、虚拟存储器概述 1. 常规存储管理方式的特征和局部性原理 (1)特征 ①一次性。 ②驻留性。 (2)局部性原理 局部性原理表现在时间局部性和空间局部性两方面。 2.虚拟存储器的定义和特征 (1)虚拟存储器的定义 虚拟存储器是指具有请求调入功能和置换功能&…

java之表格数据存储

java之表格数据存储 摘要表格数据存储javabean 介绍javabean 设计类表格数据存储 摘要 本博客主要讲述java如何存储表格数据。 表格数据存储 在解决实际问题的时候&#xff0c;需要涉及到如何存储表格的数据&#xff0c;这里讲述了一种使用javabean的方法存储表格 javabea…

STM中的I2C

常见的几种通信接口 I2C总线定义 定义 I2C - Inter-Integrated Circuit&#xff1a;两线式 串行总线&#xff1a;说明处理器和外设之间只需两根信号线&#xff0c;分别是SCL时钟控制信号线和SDA数据线 SCL&#xff08;serial clock line&#xff09; 时钟控制信号线&#xff…

makefile文件基本语法

一、makefile文件基本介绍 Makefile 文件是 make 工具使用的配置文件&#xff0c;它定义了如何自动化构建项目的规则和命令。Makefile 文件的主要作用是指定如何编译和链接程序&#xff0c;以及管理文件之间的依赖关系&#xff0c;从而实现高效的构建过程。 1.1 Makefile 的基…

【FreeRTOS】队列实验-分发数据给多个任务(赛车游戏)

目录 0 前言1 队列实验_分发数据给多个任务(赛车游戏)2 赛车游戏2.1 game.c2.2 注册队列2.3显示汽车2.4隐藏汽车2.5 CarTask2.6 car_game2.7 MX_FREERTOS_Init 3 总结 0 前言 学习视频&#xff1a; 【FreeRTOS入门与工程实践 --由浅入深带你学习FreeRTOS&#xff08;FreeRTOS教…