Двойная вставка данных с использованием модальных - PullRequest
1 голос
/ 29 апреля 2019

Я работаю над проектом PHP + MYSQL + AJAX.Я использовал Bootstrap Modal при добавлении данных.После первого нажатия кнопки «Добавить» он вставит две записи, однако это происходит только при первом щелчке.

Есть ли способ предотвратить сохранение двух записей.

Я ценю вашу помощь и предложение,Спасибо

Это мой модальный

<div id="userModal" class="modal fade">
<div class="modal-dialog">
    <form method="post" id="user_form" enctype="multipart/form-data" class="form-horizontal">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal">&times;</button>
                <h4 class="modal-title">Add User</h4>
            </div>
            <div class="modal-body">

                <div class="form-group">
                    <label class="col-lg-3 control-label">Name</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sName" maxlength="150" id="sName" placeholder="Enter your Name" />  
                        <span id='remainingC'></span>                
                    </div>
                </div>


                <div class="form-group">
                    <label class="col-lg-3 control-label">Username</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sUsername" maxlength="20" id="sUsername" placeholder="Enter your Username"/>   
                        <span id='remainingCu'></span>                
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Birthday</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sBirthday" 
                        onchange ="getAge();" maxlength="20" id="sBirthday" placeholder="YYYY-mm-dd"/>                                       
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Age</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="iAge" maxlength="3" id="iAge" placeholder="Autofill when you fill Birthday"/>                                          
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Email</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sEmail" id="sEmail" placeholder="Enter your Email - eg. jb@gmail.com"/>                                        
                    </div>
                </div>

Мои запросы AJAX

$(document).ready(function(){
$('#add_button').click(function(){
    $('#user_form')[0].reset();
    $('.modal-title').text("Add User");
    $('#action').val("Add");
    $('#operation').val("Add");
    // $('#user_uploaded_image').html('');
});

var dataTable = $('#user_data').DataTable({
    "processing":true,
    "serverSide":true,
    "order":[],
    "ajax":{
        url:"fetch.php",
        type:"POST"
    },
    "columnDefs":[
        {
            "targets":[0, 3, 4],
            "orderable":false,
        },
    ],

});

$(document).on('submit', '#user_form', function(event){
    event.preventDefault();
    var sName = $('#sName').val();
    var sUsername = $('#sUsername').val();
    var sBirthday = $('#sBirthday').val();
    var iAge = $('#iAge').val();
    var sEmail = $('#sEmail').val();

    if(sName != '' && sUsername != '' && sBirthday != '' && iAge != '' && sEmail != '')
    {
        $.ajax({
            url:"insert.php",
            method:'POST',
            data:new FormData(this),
            contentType:false,
            processData:false,
            success:function(data)
            {
                alert(data);
                $('#user_form')[0].reset();
                $('#userModal').modal('hide');
                dataTable.ajax.reload();
            }
        });
    }
    else
    {
        alert("Both Fields are Required");
    }
});

Это моя функция для добавления (insert.php)

if($_POST["operation"] == "Add")
{
    $statement = $connection->prepare("
        INSERT INTO users (sName, sUsername, sBirthday, iAge, sEmail) 
        VALUES (:sName, :sUsername, :sBirthday, :iAge, :sEmail)
    ");
    $result = $statement->execute(
        array(
            ':sName'    =>  $_POST["sName"],
            ':sUsername'    =>  $_POST["sUsername"],
            ':sBirthday'    =>  $_POST["sBirthday"],
            ':iAge' =>  $_POST["iAge"],
            ':sEmail'   =>  $_POST["sEmail"]

        )
    );
    if(!empty($result))
    {
        echo 'Data Inserted';
    }
}

Дублировать данные после первого нажатия кнопки добавления в модальном режиме: Дублировать

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...