c# - Blazor : Change image src with @Onclick without js

标签 c# linux blazor asp.net-core-3.1 .net-core-3.1

在使用了多年的 Delphi 之后,我开始学习 C#。我决定学习 blazor。 我正在尝试编写有关基本纸牌智力游戏的程序。 页面和初始页面上必须有随机图像,所有图像都带有黑色图片(0.jpg) 我正在 xxx.razor 顶部使用 for 循环创建随机图像的 id 属性

例如

<image src=0.jpg id=1>
<image src=0.jpg id=3>
<image src=0.jpg id=1>
<image src=0.jpg id=2>
<image src=0.jpg id=2>
<image src=0.jpg id=3>

当用户点击id=3 image的image属性应该是 因此将显示 img 3.jpg。

我用 jsInterop 使那个场景成为它的基础。 但我想知道我可以只使用 C# 代码吗? 坦克。 编程环境:Linux mint & Visual Studio Code & .Net Core 3.1

最佳答案

这里的问题是您需要考虑组件而不是直接写入每个元素。您应该做的是创建一个表示组件状态的对象,在您的例子中是一张具有隐藏/显示状态、文件名和源值的卡片。

下面我将这个状态称为 Image 并用类来表示它。

    public class Image
    {
        public int FileName {get;set;}
        public bool Shown {get;set;}
        public string Src => Shown ? $"{FileName}.jpg" : "0.jpg";
    }

接下来,我们需要创建一个项目集合。这可以是静态的,来自数据库等数据源。在本例中,我将使用 Enumerable.Range 函数生成范围为 1-10 的值列表。 Select 方法会将这些值分配给一个新的 Image 设置 FileName 值。这些值存储在列表中。

List<Image> items = Enumerable.Range(1, 10).Select(i => new Image { FileName = i}).ToList();

在 UI 部分,我们需要渲染一些标记。图片在这里可以很好地工作,但是按钮更容易用于示例目的。在 onclick 事件中,我们只需将 Shown 值设置为 true。设置此值会更新显示“已显示”图像 1-10.jpg 的 Src 属性。

@foreach (var item in items) {
    <button @onclick="@(()=> item.Shown = true)">@item.Src</button>
}

把它们放在一起你有:

@foreach (var item in items) {
    <button @onclick="@(()=> item.Shown = true)">@item.Src</button>
}

@code {
    List<Image> items = Enumerable.Range(1, 10).Select(i => new Image { FileName = i}).ToList();

    public class Image
    {
        public int FileName {get;set;}
        public bool Shown {get;set;}
        public string Src => Shown ? $"{FileName}.jpg" : "0.jpg";
    }
}

您可以将按钮替换为您任务的图像。

<img src="@item.Src" @onclick="@(()=> item.Shown = true)" />

在此处查看实时有效的解决方案 https://blazorfiddle.com/s/m01smajj

如果你想打开/关闭显示

@foreach (var item in items) {
    <button @onclick="@(()=> item.Shown = !item.Shown)">@item.Src</button>
}

关于c# - Blazor : Change image src with @Onclick without js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59975764/

相关文章:

c# - 在代码后面执行授权检查

c# - 从浏览器控制我的应用程序?

linux - Wordpress 无法在 CentOS 6.2 上运行

linux - 服务器到服务器文件传输端口?

c - 如何以编程方式为接口(interface)获取 linux 接口(interface)别名(IFLA IFALIAS)?

c# - 如何将 EventCallback<T> 转换为 EventCallback<bool>

c# - 为什么TemplateBinding无法绑定(bind)Button.Content?

c# - 仅当具有唯一 11 字符代码的所有文件都存在时才处理文件

c# - 将 SAFEARRAY 从 C# 传递到 COM

Blazor 客户端调试