簡體   English   中英

是否有可能在不使用加載調用的情況下將表單綁定到模態引導程序 window?

[英]Is there a possibility to bind the Form to a modal bootstrap window without using the load call?

我正在使用 ajax 發出請求並隨后打開模態引導程序 window 。 問題是,當我使用 ajax 時,我向我的 controller 發出請求,返回(模態內容)我加載如下:

//modal loading
$('#contentModalFinanceiroParcela').html(data);

//exibição da modal
$('#modalFinanceiroParcela').modal({
    keyboard: true,
}, 'show');

到目前為止,一切都很完美。 問題是從那以后,我無法綁定表單來注冊表單的提交事件。 在 function bindFormFinanceiroParcela 中,無論我通過多少“對話框”,bind 都不起作用。

bindFormFinanceiroParcela(document.getElementById("contentModalFinanceiroParcela"));

搜索論壇,我發現如果我使用“加載”命令加載模式,該過程可以工作,如下所示,但我不能這樣做,否則它將向 controller 發出第二次請求,因為之前,我已經用過 ajax。

//That way it works, but I can't use it.
$('#contentModalFinanceiroParcela').load(url, function () {
    $('#modalFinanceiroParcela').modal({
        keyboard: true
    }, 'show');

    // Inscreve o evento submit
    bindFormFinanceiroParcela(this);

    stopLoadPage();
});

是否有可能我可以在不使用上面腳本中提到的“加載”命令的情況下綁定表單?

    function openModalFinanceiroParcelaSemURL(data) {
    startLoadPage();

    //Create the modal window block in the body of the page
    if (!$("#modalFinanceiroParcela").data('bs.modal'))
        CreateModalFinanceiroParcela();

    //Load modal content via ajax request
    $('#contentModalFinanceiroParcela').html(data);

    $('#modalFinanceiroParcela').modal({
        keyboard: true,
    }, 'show');

   bindFormFinanceiroParcela(document.getElementById("contentModalFinanceiroParcela"));

   
    
    stopLoadPage();
}

function bindFormFinanceiroParcela(dialog) {
$('form', dialog).submit(function (e, i) {
    if ($(this).valid() || i) {
        startLoadOneMoment();
        $.ajax({
            url: this.action,
            type: this.method,
            data: $(this).serialize(),
            success: function (result) {
                if (result.success) {
                     window.location = window.location;                       
                } else {
                    $('#contentModalFinanceiroParcela').html(result);
                    bindFormFinanceiroParcela();
                }
                stopLoadOneMoment();
            }
        });
        return false;
    } else {
        return false;
    }
});

function CreateModalFinanceiroParcela() {
var html = '<div class="modal modal-primary modal-system" tabindex="-1" role="dialog" id="modalFinanceiroParcela" data-backdrop="static"><div class="modal-dialog modal-dialog-centered"><div class="modal-content"><div class="content-modal-system" id="contentModalFinanceiroParcela"></div></div></div></div>';

$("body").append(html);
}

RAZOR 刪除:

@using Retaguarda.Domain.Enuns
@model Retaguarda.Application.ViewModels.Financeiro.FinanceiroParcela.FinanceiroParcelaViewModel
@{
    ViewData["Title"] = "Excluir Parcela";
    Layout = null;
}
<div>
    <form asp-action="Delete" id="frm-excluir-financeiro-parcela">
        @Html.AntiForgeryToken()

        <div class="modal-shadow">
            <div class="modal-header modal-header-primary">
                <button type="button" class="close" data-dismiss="modal"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button>
                <h4><i class="modal-title text-center glyphicon glyphicon-trash"></i> @ViewData["Title"] </h4>
            </div>
            <div class="panel">
                <div class="panel-body  container-fluid pt-15 pl-15 pr-15">
                    <div class="form-horizontal">
                        <vc:summary />
                        <br />
                        <div class="message-delete">
                            @Html.HiddenFor(model => model.Id, new { id = "hid-financeiro-parcela-id" })
                            <i class="icon fa-trash" aria-hidden="true"></i>
                            <p>
                                Tem certeza de que deseja excluir a parcela @(Model.Parcela)?<br />
                            </p>
                        </div>
                    </div>
                </div>
            </div>

            <div class="modal-footer">
                <div class="col-md-offset-2 col-md-10">
                    <div class="float-right">
                        <div class="btn-group btn-group-sm mr-auto"
                             role="group">
                            <div class="btn-group btn-group-sm" role="group">
                                @*<button id="btn-excluir-financeiro-parcela" type="submit" class="btn btn-success"><i class="icon wb-check"></i> Excluir </button>*@
                                <button id="btn-excluir-financeiro-parcela" type="button" class="btn btn-success"><i class="icon wb-check"></i> Excluir </button>
                                <button id="btn-cancelar-financeiro-parcela" class="btn btn-danger" data-dismiss="modal"><i class="icon wb-close"></i> Cancelar </button>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </form>
</div>

<script src="~/lib/jquery-validation/dist/jquery.validate.js"></script>
<script src="~/lib/jquery-validation-unobtrusive/jquery.validate.unobtrusive.js"></script>


@section Scripts {
    @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
}

Ajax 調用

$('#dtFinanceiroParcela').on('click', 'tr .btn-excluir-financeiro-parcela', function (e) {
e.preventDefault();

startLoadOneMoment();

var id = $(this).attr('data-id');
var data = { id: id };
var dataURL = jQuery.param(data);

$.ajax({
    url: "/financeiro-parcela-gerenciar/remover-financeiro-parcela/" + id,
    type: "GET",
   // data: dataURL,
    contentType: "application/json",
    async: false,
    success: function (result) {
        if (typeof result.success !== 'undefined') {
            if (!result.success) {
                stopLoadOneMoment();

                swal("Oops", result.message, "error");

                return false;
            }
        }
       // alert(this.url);
        stopLoadOneMoment();
        openModalFinanceiroParcelaSemURL(result);
        
        return false;
    },
    error: function () {
        stopLoadOneMoment();
        alert("Oops! Algo deu errado.");
        return false;
    }
});

您在 razor 中的表單不包含任何提交按鈕,因為它已被注釋掉。

@*<button id="btn-excluir-financeiro-parcela" type="submit" class="btn btn-success"><i class="icon wb-check"></i> Excluir </button>*@

刪除評論或將其他按鈕的類型更改為“提交”

我猜提交事件已成功附加,但由於表單中缺少提交按鈕而從未調用過。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM