【Blazor】Blazor学习笔记

  1. 布局

如何创建布局,也就是页面的模板

@inherits LayoutComponentBase

必须继承LayoutComponentBase

当然也可以在其他的布局的基础之上,嵌入自己的自定义布局形成新的布局

@layout 其他布局

====

@inherits LayoutComponentBase->布局基类

@layout MainLayout->其他的布局

@Body

====

如何选择布局应用的范围

  1. 针对个体

在razor文件开头就写

@layout 某某布局

  1. 针对范围

利用_Imports.razor,在指定文件夹下的所有布局都会按照_Imports.razor来处理

  1. 组件

如何创建一个组件

前端+C#

注意组件前面要加@rendermode InteractiveServer

因为组件是需要交互的

如何单向绑定

需要绑定的对象在C#代码区加[Parameter],并且public,前端区@变量名访问

仅仅是C#->前端的数据流向

如何访问DOM

@onxxxx,就可以访问html组件的DOM事件了,之后可以@与C#区域联动,或者直接上lambda表达式

访问某些事件是具备属性的,@onxxxx:yyyy,输入:可以弹出事件的一些属性来,相当于进一步细化事件的使用。

如何双向绑定

就是实现数据在前端区域和C#区域双向传递

@* @bind 和 @bind-value 的区别 *@

@* 特性 @bind @bind-value *@

@* 语法简洁性 更简洁,适合大多数场景 更显式,适合复杂场景 *@

@* 默认绑定属性 自动绑定到 value 属性 显式绑定到 value 属性 *@

@* 默认事件 默认绑定到 onchange 事件 需要显式指定事件(如 oninput) *@

@* 适用场景 普通 HTML 元素或简单组件 自定义组件或需要显式控制的场景 *@

@* 灵活性 较低,适合简单绑定 较高,适合需要精细控制的场景 *@

废话不多说,直接看总结,就是看使用场景是简单还是复杂

如何解决父组件,子组件的参数传递

级联访问指令

  1. 可以按照"名字"进行索引,这个CascadingValue范围内的对象都可以通过"级联访问名索引"

需要多个不同的级联索引,就套娃多写几层

在父组件

<CascadingValue Value="@C#区域变量名" Name="级联访问识别名">

@* 希望进行级联索引的子组件 *@

</CascadingValue>

在子组件的C#区域,通过[CascadingParameter(Name = "级联访问识别名")]来提取父组件传递进来的信息,然后再通过@标记传到子组件的前端区域

  1. 可以按照类型进行索引,也是类似于名字索引

在父组件

<CascadingValue Value="@C#区域变量名" >

@* 希望进行级联索引的子组件 *@

</CascadingValue>

其实就是不用写那个Name了,框架自动根据C#变量区域的类型推断,方便不用名字

在子组件的C#区域[CascadingParameter]提取就完了,省事

  1. 级联传递时的值覆写问题

框架在按照名字进行索引的时候,会出现级联传递的名字一样的情况,这种情况下就会发生在传递过程中的覆写问题,框架并不禁止这种行为,可以在过程中组件将上一级传递的值修改,然后再往下传递。

相关推荐
“抚琴”的人19 小时前
【机械视觉】C#+VisionPro联合编程———【六、visionPro连接工业相机设备】
c#·工业相机·visionpro·机械视觉
云上艺旅19 小时前
K8S学习之基础七十四:部署在线书店bookinfo
学习·云原生·容器·kubernetes
你觉得20520 小时前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义下载方法
大数据·人工智能·python·gpt·学习·机器学习·aigc
A旧城以西21 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
无所谓จุ๊บ21 小时前
VTK知识学习(50)- 交互与Widget(一)
学习·vtk
FAREWELL0007521 小时前
C#核心学习(七)面向对象--封装(6)C#中的拓展方法与运算符重载: 让代码更“聪明”的魔法
学习·c#·面向对象·运算符重载·oop·拓展方法
吴梓穆21 小时前
UE5学习笔记 FPS游戏制作38 继承标准UI
笔记·学习·ue5
CodeCraft Studio21 小时前
Excel处理控件Spire.XLS系列教程:C# 合并、或取消合并 Excel 单元格
前端·c#·excel
Three~stone1 天前
MySQL学习集--DDL
数据库·sql·学习
齐尹秦1 天前
HTML 音频(Audio)学习笔记
学习