jQuery如何仅在表单具有某些数据数组时提交更改的字段

Jer*_*ryc 1 html javascript jquery

我有一个具有一对多关系的数据库结构。在html格式中,有类似的输入,其名称为“ item []”或“ file []”,以使数据成为数组

<form action="submit.php" method="get">
  Name:<input type="text" name="name"/><br/>
  Item:<input type="text" name="item[]"/><br/>
  File:<input type="file" name="file[]" multiple/>
  Item:<input type="text" name="item[]"/><br/>
  File:<input type="file" name="file[]" multiple/>
  Select:<select name="select" value="1" original="1">
  <option value="1">One</option>
  <option value="2">Two</option>
  </select>

</form>
Run Code Online (Sandbox Code Playgroud)

我该如何只提交更改的字段,并且在服务器端我可以确认更改了哪个项目?我尝试禁用输入,但似乎不起作用。

另一个问题是,如果我使用ajax提交表单,该如何提交文件

Ufg*_*llu 5

您可以使用jQuery解决此问题,并在每次更改后添加一个类,然后input
可以inputs不使用该类而禁用所有内容并提交表单

$(document).ready(function() {
  $('input, select, textarea').on('change', function() {
    $(this).addClass('changed');
  });
  
  $('form').on('submit', function() {
    $('input:not(.changed), textarea:not(.changed)').prop('disabled', true);
    
    // alert and return just for showing
    alert($(this).serialize().replace('%5B', '[').replace('%5D', ']'));
    return false;
  });
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<form action="submit.php" method="get">
  Name:<input type="text" name="name" /><br/><br/>
  Item:<input type="text" name="item[]" /><br/><br/>
  File:<input type="file" name="file[]" multiple /><br/><br/>
  Item:<input type="text" name="item[]" /><br/><br/>
  File:<input type="file" name="file[]" multiple /><br/><br/>
  Select:<select name="select" value="1" original="1">
  <option value="" selected="selected" disabled="disabled"></option>
  <option value="1">One</option>
  <option value="2">Two</option>
  </select><br/><br/>
  <button type="submit">send</button>
</form>
Run Code Online (Sandbox Code Playgroud)

您可以像这样在name属性中使用索引 <input type="text" name="item[1]" />