单击时清除 jQuery 表单字段

标签 jquery forms click

我创建了一个表单,其中包含一个用于街道地址的对话框搜索框和一个用于邮政地址的对话框搜索框。它的工作原理是,当您单击搜索结果时,它会根据您单击的按钮填充街道或邮政地址。一切正常,除了当您单击搜索结果时,它会清除其他地址的字段填充。据我所知,这一切都与点击功能有关。任何帮助将不胜感激,谢谢

例如: 如果我单击“邮政地址”按钮并单击搜索结果,它将填充邮政地址字段。然后,如果我单击“街道地址”按钮,它将填充“街道地址”字段,但也会清除“邮政地址”字段。

代码

<!-- STREET ADDRESS -->
<script type="text/javascript">
  $(document).ready(function() {
    $('#table-data tr').click(function () {
      var curRowClass = $(this).attr("class");
      $('#street_name').val( $('.' + curRowClass + ' td.address_street').text() );
      $('#suburb').val( $('.' + curRowClass + ' td.address_suburb').text() );
      $('#city').val( $('.' + curRowClass + ' td.address_city').text() );
      $("#modal_form").dialog('close');
    });
  });
</script>

<!-- POSTAL ADDRESS -->
<script type="text/javascript">
  $(document).ready(function() {
    $('#table-data tr').click(function () {
      var curRowClass = $(this).attr("class");
      $('#street_name_classy').val( $('.' + curRowClass + ' td.address_street_classy').text() );
      $('#suburb_classy').val( $('.' + curRowClass + ' td.address_suburb_classy').text() );
      $('#city_classy').val( $('.' + curRowClass + ' td.address_city_classy').text() );
      $("#modal_form").dialog('close');
    });
  });
</script>

如果您需要,我可以发布更多代码,但我已将其范围缩小到他的点击函数,在导致问题的脚本中。

谢谢

最佳答案

您将两个事件处理程序(两个 click 处理程序)连接到同一个选择器 (#table-data tr)。因此,当您单击该按钮(看起来像同一个按钮)时,它将触发两个单击处理程序。

我不确定您如何获取数据,但您应该考虑使用两个不同的处理程序和某种标志来确定哪个分支被触发。

$('#table-data tr').click(function () {
  if(do_street_address_work) {
    //your logic for populating the street address
  } else {
    //your logic for populating the postal address
  }
}

关于单击时清除 jQuery 表单字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7155265/

相关文章:

javascript - 如何停止在移动设备上滚动完整日历?

javascript - 验证具有未知 id 和公共(public)类的动态 HTML Select 的空值

html - 具有相同名称的两个输入元素是否有效?

jQuery 选择、.change 和 .click

Javascript - 单击不同按钮时单击具有类或 id 的多个元素

Jquery datepicker 禁用具有范围的多个日期

javascript - 如何在JavaScript中实现异步函数之间的依赖?

javascript - 显示 Rails 3 UJS 的微调器出现类型错误

php - codeigniter:我在数据库中有行(就像博客文章、标题、帖子正文等)。有什么方法可以提交表单+保存提交?

android - 更改抽屉导航中的布局