Blazor:在没有 js 的情况下使用 @Onclick 更改图像 src

Ahm*_*nav 1 c# linux blazor .net-core-3.1 asp.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>
Run Code Online (Sandbox Code Playgroud)

当用户单击 id=3 图像图像属性时,将显示 img 3.jpg。

我用 jsInterop 把那个场景变成了它的基础。但我想知道我可以只用 C# 代码做到这一点吗?恩克斯。编程环境:Linux mint & Visual Studio Code & .Net Core 3.1

Ed *_*eau 8

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

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

    public class Image
    {
        public int FileName {get;set;}
        public bool Shown {get;set;}
        public string Src => Shown ? $"{FileName}.jpg" : "0.jpg";
    }
Run Code Online (Sandbox Code Playgroud)

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

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

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

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

把它们放在一起,你有:

@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";
    }
}
Run Code Online (Sandbox Code Playgroud)

您可以使用任务的图像替换按钮。

<img src="@item.Src" @onclick="@(()=> item.Shown = true)" />
Run Code Online (Sandbox Code Playgroud)

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

如果要打开/关闭显示

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