Blazor 子组件交互例子

2024-02-12 01:04
文章标签 组件 交互 例子 blazor

本文主要是介绍Blazor 子组件交互例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

源码

子组件 SwitchBar.razor

@using Microsoft.Extensions.Logging
@inject ILogger<Index> Logger<div style="@ClassString" @onclick="OnClick">@ChildContent
</div>@code {[Parameter]public RenderFragment? ChildContent { get; set; }[Parameter]public int Value { get; set; }[Parameter]public EventCallback<int> ValueChanged { get; set; }[Parameter]public EventCallback<bool> Initiated { get; set; }private string? ClassString =>  Value<5? "height:100px;color:red;" : "height:100px;color:green;";protected override async Task OnAfterRenderAsync(bool firstRender){if (firstRender){await Task.Delay(2000); await Initiated.InvokeAsync(true);}}private async Task OnClick(){Value ++;if (ValueChanged.HasDelegate){await ValueChanged.InvokeAsync(Value);}}
}

主组件页面 SwitchBarDemo.razor

@page "/SwitchBarDemo"@using Microsoft.Extensions.Logging
@inject ILogger<Index> Logger<SwitchBar ValueChanged="OnValueChanged" Initiated="OnInitiated"><div>我是子组件1内容, 点击++</div>
</SwitchBar>@*<SwitchBar ValueChanged="OnValueChanged"><div>我是子组件2内容</div>
</SwitchBar>*@<div style="@ClassString"><h3>主组件</h3>@message @Value@for (int i = 0; i < Value2; i++){<div>渲染 Table</div>} </div>@code {[Parameter]public bool Value { get; set; }int Value2;string message = "我是主组件内容";private string? ClassString => Value ? "height:200px;color:red;" : "height:100px;color:green;";protected override async Task OnAfterRenderAsync(bool firstRender){if (firstRender){//message += "主组件加载";//StateHasChanged();//await Task.Delay(1000);//message += ",主组件加载完成";//StateHasChanged();}}private async Task OnInitiated(bool val){message += ",子组件加载完成(查询角色)";StateHasChanged();Value2 = 2;Value = val;await Task.Delay(1000);StateHasChanged();}private Task OnValueChanged(int val){Value2= val;message += "子组件数据变化";StateHasChanged();return Task.CompletedTask;}
}

运行效果

这篇关于Blazor 子组件交互例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/701278

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

Python与Java交互出现乱码的问题解决

《Python与Java交互出现乱码的问题解决》在现代软件开发中,跨语言系统的集成已经成为日常工作的一部分,特别是当Python和Java之间进行交互时,编码问题往往会成为导致数据传输错误、乱码以及难... 目录背景:为什么会出现乱码问题产生的场景解决方案:确保统一的UTF-8编码完整代码示例总结在现代软件

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n