Blazor-在删除/更新之前显示确认对话框?

时间:2019-11-05 21:19:39

标签: c# razor blazor

在以下Blazor(服务器端)代码片段中。如何提示确认对话框?

<tbody>
    @foreach (var r in lists)
    {
        var s = r.ID;
        <tr>
            <td>@s</td>
            <td><button class="btn btn-primary" @onclick="() => DeleteSymbol(s)">Delete</button></td>
        </tr>
    }
</tbody>

@code {
    async Task DeleteSymbol(string id)
    {
        // Get confirmation response from user before running deletion?
        // Delete!
    }
}

3 个答案:

答案 0 :(得分:5)

我创建了一个简单的popconfirm组件。

 <div class="pop-container">
        @if (Show)
        {
            <div class="popconfirm">
                @Message
                <button type="button" class="btn btn-warning" @onclick="() => Confirmation(false)">No</button>
                <button type="button" class="btn btn-primary" @onclick="() => Confirmation(true)">Yes</button>
            </div>

        }
        <button type="button" class="@Class" @onclick="ShowPop">@Title</button>
    </div>
    @code {
        public bool Show { get; set; }
        [Parameter] public string Title { get; set; } = "Delete";
        [Parameter] public string Class { get; set; } = "btn btn-danger";
        [Parameter] public string Message { get; set; } = "Are you sure?";
        [Parameter] public EventCallback<bool> ConfirmedChanged { get; set; }

        public async Task Confirmation(bool value)
        {
            Show = false;
            await ConfirmedChanged.InvokeAsync(value);
        }

        public void ShowPop()
        {
            Show = true;
        }
    }

CSS

.pop-container{
    position: relative;
}

.popconfirm{
    background-color: white;
    border-style: solid;
    border-width: 1px;
    border-color: lightblue;
    width: 250px;
    position: absolute;
    top: -50px;
    padding: 10px;
    border-radius: 8px;
}

用法

<Popconfirm ConfirmedChanged="Test" />
@code{

    public void Test(bool test)
    {
        Console.WriteLine(test);
    }
}

答案 1 :(得分:4)

@inject IJSRuntime JsRuntime

<tbody>
...
</tbody>

@code {
    async Task DeleteSymbol(string id)
    {
        bool confirmed = await JsRuntime.InvokeAsync<bool>("confirm", "Are you sure?");
        if (confirmed)
        {
            // Delete!
        }
    }
}

答案 2 :(得分:2)

我使用了@Egill的答案,并对其进行了扩展,使其更符合我的要求。 这就是我所需要的。

  1. 删除按钮作为图片。 (使用ion-icons

btn-trash-icon

  1. 背景已禁用
  2. 位于屏幕中央的弹出窗口

enter image description here

使用RenderFragments满足特定要求。

这就是我最终得到的结果。

组件:

    <div>
    <button type="button" class="@Class" @onclick="ShowPop">
        @if (ButtonContent != null)
        {
            @ButtonContent
        }
        else
        {
            @Title
        }
    </button>
    @if (Show)
    {
        <div class="pop-container">
            <div class="popconfirm gradient-to-gray">
                <div class="row">
                    <div class="col">
                        @if (MessageTemplate != null)
                        {
                            @MessageTemplate
                        }
                        else
                        {
                            @Message
                        }
                    </div>
                </div>
                <div class="row">
                    <div class="col-6">
                        <button type="button" class="btn @YesCssClass" @onclick="() => Confirmation(true)">Yes</button>
                    </div>
                    <div class="col-6">
                        <button type="button" class="btn @NoCssClass" @onclick="() => Confirmation(false)">No</button>
                    </div>
                </div>
            </div>
        </div>
    }
</div>

@code {
    public class MessageTemp
    {
        public string msg { get; set; }
    }

    public bool Show { get; set; }

    [Parameter]
    public string Title { get; set; } = "Delete";

    [Parameter]
    public string Class { get; set; } = "btn btn-danger";

    [Parameter]
    public string YesCssClass { get; set; } = "btn btn-success";

    [Parameter]
    public string NoCssClass { get; set; } = "btn btn-warning";

    [Parameter]
    public string Message { get; set; } = "Are you sure?";

    [Parameter]
    public EventCallback<bool> ConfirmedChanged { get; set; }

    [Parameter]
    public RenderFragment ButtonContent { get; set; }

    [Parameter]
    public RenderFragment MessageTemplate { get; set; }

    public async Task Confirmation(bool value)
    {
        Show = false;
        await ConfirmedChanged.InvokeAsync(value);
    }

    public void ShowPop()
    {
        Show = true;
    }
}

CSS:

.pop-container {
    z-index: 1000;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0px;
    left: 0px;
    background-color: rgba(132, 4, 4, 0.77);
}

.popconfirm {
    color: white;
    background-color: gray;
    border-style: solid;
    border-width: 1px;
    border-color: lightblue;
    padding: 10px;
    border-radius: 15px;
    min-width: 250px;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.pop-message-card, .pop-message-card div {
    background-color: rgba(0, 0, 0, 0.00) 
}

.gradient-to-gray {
    background: linear-gradient(0deg,#000000,#888);
    color: #fff;
}

.btn-yes {
    background-color: darkgreen;
    color: limegreen;
    width: 100%;
}

.btn-no {
    background-color: darkred;
    color: lightcoral;
    width: 100%;
}

用法:

<ConfirmPopup Title="Delete Unit" 
    Message="Delete record?" 
    Class="btn btn-psl-delete" 
    YesCssClass="btn-yes"
    NoCssClass="btn-no"
    ConfirmedChanged="DeleteRecord">
        <ButtonContent>
            <ion-icon name="trash-outline" style="font-size:2em;color:white;"></ion-icon>
        </ButtonContent>
        <MessageTemplate>
            <div class="card pop-message-card">
                <div class="card-header">
                    Delete Record?
                </div>
                <div class="card-body">
                    <p>
                        This will delete the record!<br />
                        Are you sure?
                    </p>
                </div>
            </div>
        </MessageTemplate>
</ConfirmPopup>