2015-12-30 2 views
2

Я пытаюсь отправить форму с помощью jquery/AJAX, но моя функция никогда не вызывается, когда я нажимаю кнопку отправки.Отправка формы с помощью jquery/AJAX не работает при нажатии кнопки отправки

Мой сайт выглядит так: CarMenu.php

<html lang="en"> 
<html> 
<head> 
    <meta charset="ISO-8859-1"> 
    <title>ArsenalAutoBrokers - Backend - add car</title> 
    <link rel="stylesheet" href="../js/jquery-ui-1.11.4/jquery-ui.min.css"  type="text/css"/> 
    <link rel="stylesheet" href="../js/jquery-ui-1.11.4/jquery-ui.css" type="text/css"/> 
    <link rel="stylesheet" href="../js/jquery-ui-1.11.4/jquery-ui.theme.css" type="text/css"/> 
    <link rel="stylesheet" href="../js/jquery-ui-1.11.4/jquery-ui.structure.css" type="text/css"/> 
    <link rel="stylesheet" href="../css/carForm.css" type="text/css"/> 
    <script charset="UTF8" src="../js/jquery/jquery-1.11.3.js"></script> 
    <script charset="UTF8" src="../js/jquery-ui- 1.11.4/external/jquery/jquery.js"></script> 
    <script charset="UTF8" src="../js/jquery-ui-1.11.4/jquery-ui.js"></script> 
    <script charset="UTF8" src="../js/app/carForm.js"></script> 
    <script charset="UTF8" src="../js/app/addCar.js"></script> 
</head> 
<body> 
    <div id="container"> 
     <div id="leftMenuContainer"> 
     <ul id="menu"> 
      <li id="addCarItem">Add car</li> 
      <li id="saveCarItem">Edit cars</li> 
     </ul> 
     </div> 
     <div id="rightMainContent"> 

     </div> 
     <div class="clear"></div> 
    </div> 
    </body> 
</html> 

На этой странице, я использую меню JQuery и я загрузки данных в DIV с идентификатором «rightMainContent».

Javascript код, чтобы сделать это выглядит следующим образом: carForm.js

$(document).ready(function() { 
    $("#menu").menu({ 
    select: function(event, ui) { 
     if (ui.item.attr('id') === 'addCarItem') { 
      $("#rightMainContent").load(
      '/CarDealer/CarForm/CreateCar/AddCar.php');  
     } 
    } 
}); 
}); 

Если вы нажмете на «addCar» пункт меню части сайта будут загружаться с этого сайта PHP:

<script type="text/javascript"> 

$('input[type=submit]').button(); 
//$('#activeCheck').button(); 
$("#activeCheck").attr('checked','checked'); 
$('#saveButton').hide(); 
$('#tabs').tabs(); 
$('#accordion').accordion({heightStyle: "content"}); 

$('#tabs').tabs({ 
    activate: function (event, ui) { 
     var act = $("#tabs").tabs("option", "active"); 
     if (act == 0 || act == 1) { 
      $('#saveButton').hide(); 
     } else { 
      $('#saveButton').show(); 
     } 
    } 
}); 

$('#fileToUpload').on('change', function(){ 
    var fileSelect = document.getElementById('fileToUpload'); 
    var files = fileSelect.files; 

    if (files.length > 10) { 
    $('.info').html('The file upload is limited to <font color="red"><b>10 pictures per car</b></font>.<br>Only the 1st ten pictures will be stored.'); 
    $('.info').show(); 
    } else { 
     $('.info').html(''); 
    $('.info').hide(); 
    } 

}); 

</script> 

<form id="carSaveForm" 
    action="/CarDealer/CarForm/CreateCar/CarCreation.php" method="POST" 
    enctype="multipart/form-data"> 
    <div id="tabs"> 
     <ul> 
      <li><a href="#tabsGen">General Car Information</a></li> 
      <li><a href="#tabsDescr">Car Descriptions</a></li> 
      <li><a href="#tabsPics">Picture Upload</a></li> 
     </ul> 
     <div id="tabsGen"> 
    <?php include($_SERVER['DOCUMENT_ROOT']."/CarDealer/CarForm/CreateCar/carGeneralData.php"); ?> 
    </div> 
     <div id="tabsDescr"> 
    <?php include($_SERVER['DOCUMENT_ROOT']."/CarDealer/CarForm/CreateCar/carDescriptions.php"); ?> 
    </div> 
     <div id="tabsPics"> 
    <?php include($_SERVER['DOCUMENT_ROOT']."/CarDealer/CarForm/CreateCar/PictureUpload.php"); ?> 

    </div> 
    </div> 
    <br> <input id="saveButton" type="submit" name="submit" value="save" /> 
</form>  

Этот сайт содержит только элементы формы, такие как кнопки ввода, сборщики файлов и т. Д.

Ну, пока все хорошо. Все отображается неправильно, но если я нажав на кнопку отправки эта функция не получает под названием: addCar.js

$('#carSaveForm').on('submit', function(event){ 
     event.preventDefault(); 

     var formData = new FormData(); 
     // get the form data 
     // there are many ways to get this data using jQuery (you can use the class or id also) 
     formData.append('carBrand'    , $('input[name=carBrand]').val()); 
     formData.append('carModelYear'   , $('input[name="carModelYear"]').val()); 
     formData.append('carModel'    , $('input[name=carModel]').val()); 
     formData.append('carTrim'    , $('input[name="carTrim"]').val()); 
     formData.append('carDriveTrain'   , $('input[name="carDriveTrain"]').val()); 
     formData.append('carCondition'   , $('input[name="carCondition"]').val()); 
     formData.append('carType'    , $('input[name="carType"]').val()); 
     formData.append('carFuelType'   , $('input[name="carFuelType"]').val()); 
     formData.append('carTransmission'  , $('input[name="carTransmission"]').val()); 
     formData.append('carEngine'    , $('input[name="carEngine"]').val()); 
     formData.append('carCylinder'   , $('input[name="carCylinder"]').val()); 
     formData.append('carMileage'    , $('input[name="carMileage"]').val()); 
     formData.append('carExteriorColor'  , $('input[name="carExteriorColor"]').val()); 
     formData.append('carInteriorColor'  , $('input[name="carInteriorColor"]').val()); 
     formData.append('carLocation'   , $('input[name="carLocation"]').val()); 
     formData.append('carVin'     , $('input[name="carVin"]').val()); 
     formData.append('carStock'    , $('input[name="carStock"]').val()); 
     formData.append('carPrice'    , $('input[name="carPrice"]').val()); 
     formData.append('carPriceDetails'  , $('input[name="carPriceDetails"]').val()); 
     formData.append('carTax'     , $('input[name="carTax"]').val()); 
     formData.append('carTaxDetails'   , $('input[name="carTaxDetails"]').val()); 
     formData.append('carCurrency'   , $('input[name="carCurrency"]').val()); 
     formData.append('carOnline'    , $('input[name="carOnline"]').val()); 
     formData.append('carDescr'    , $('input[name="carDescr"]').val()); 
     formData.append('carBodyDescr'   , $('input[name="carBodyDescr"]').val()); 
     formData.append('carDriveTrainDescr'  , $('input[name="carDriveTrainDescr"]').val()); 
     formData.append('carExteriorDescr'  , $('input[name="carExteriorDescr"]').val()); 
     formData.append('carElectronicsDescr' , $('input[name="carElectronicsDescr"]').val()); 
     formData.append('carSaftyFeaturesDescr' , $('input[name="carSaftyFeaturesDescr"]').val()); 
     formData.append('carSpecialFeaturesDescr', $('input[name="carSpecialFeaturesDescr"]').val()); 

     var fileSelect = document.getElementById('fileToUpload'); 
     var files = fileSelect.files; 
     // Loop through each of the selected files. 
     for (var i = 0; i < files.length; i++) { 
      var file = files[i]; 

      // Add the file to the request. 
      formData.append('files[]', file, file.name); 
     } 

     // process the form 
     $.ajax({ 
      type  : 'POST', // define the type of HTTP verb we want to use (POST for our form) 
      url   : '/CarDealer/CarForm/createCar/carCreation.php', // the url where we want to POST 
      data  : formData, // our data object 
      contentType: false, 
      processData: false, 
      success: function (data) { 
       $('.success').fadeIn(200).show(); 
       $('.error').fadeOut(200).hide(); 
      }, 
      error: function (data) { 
       $('.success').fadeIn(200).hide(); 
       $('.error').fadeOut(200).show(); 
      } 

     }); 
     return false; 
    }); 

я не имею ни малейшего понятия, почему эта функция никогда не вызывался, я попробовал все, я гугле много, но я не понимаю. Я искал ошибку весь день, но я не вижу ее.

Пожалуйста, помогите мне.

Ваша помощь приветствуется.

Заранее спасибо.

+0

использовать форму сериализации для этих значений – devpro

+0

Спасибо за подсказку. Я пробовал, но он не работает с файлами, я думаю. – F4k3d

ответ

5

JQuery является только узнавая о элементах на странице во время их запуска, поэтому новые элементы, добавленные в DOM, не распознаются jQuery. Для борьбы с этим используйте event delegation, пузырящиеся события из недавно добавленных элементов до точки в DOM, которая была там, когда jQuery выполнялся при загрузке страницы. Многие люди используют document как место, где можно поймать пузырьковое событие, но не обязательно идти так высоко в дерево DOM. В идеале you should delegate to the nearest parent that exists at the time of page load.

Например, эта кнопка была добавлена ​​к DOM с помощью AJAX:

<input id="saveButton" type="submit" name="submit" value="save" /> 

Для того, чтобы правильно обращаться с этим (, если это единственная форма с этим идентификатором добавлена ​​к странице) заключается в делегировании щелчок или отправить событие:

$(document).on('click', '#saveButton', function(event) {... 

Кроме того, если вы будете продолжать добавлять формы, как вы показать здесь, вы будете иметь дублированные идентификаторы на странице и id's must be unique. Неспособность сделать их уникальными приведет к ряду проблем.

Обязательно просмотрите запрос/ответ AJAX в консоли браузера as outlined here, чтобы найти и исправить ошибки, которые могут возникнуть.

+0

Спасибо, Джей Бланшар. Это было ново для меня. Теперь я узнал что-то новое. – F4k3d

2

изменение $('#carSaveForm').on('submit', function(event) в $('#carSaveForm').on('click','#saveButton', function(event)

-2

Cut (Ctrl + X) этой линии от CarMenu.php

<script charset="UTF8" src="../js/app/addCar.js"></script> 

и вставить (Ctrl + V) сценария в AddCar.php

 Смежные вопросы

  • Нет связанных вопросов^_^