【问题标题】:Uncaught TypeError: Cannot read properties of undefined (reading 'preventDefault')未捕获的类型错误:无法读取未定义的属性(读取“preventDefault”)
【发布时间】:2022-01-17 07:01:46
【问题描述】:

我根据特定流程在输入中触发 onchange 属性。但是,即使我将“事件”作为参数,我仍然会继续收到以下错误。另外,或者,我尝试了 Event.StopPropagation () 和 Return False,但问题仍然存在。

$(function () {
        test();
});

function test(obj) {

        var inputValue = parseInt($(obj).val());

        if (($(obj).val() < 0 || $(obj).val() > 100) && event.keyCode !== 46 // keycode for delete
            && event.keyCode !== 8 // keycode for backspace
        ) {
            event.preventDefault();
            $(obj).val(0);
        } else if (isNaN(inputValue)) {
            event.preventDefault();
            $(obj).val(0);
        }
}
<script src="https://code.jquery.com/ui/1.13.0/jquery-ui.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.0/jquery.min.js"></script>

<div>
<input id="weightInput" type="number" class="form-control weightInput"  data-key="" data-guid="" onchange="test(this)" value="" />
</div>

【问题讨论】:

  • event 未在您的函数中定义。不要在事件处理程序中使用test(this),只需将test() 放在事件处理程序中并使用this 关键字来引用该元素。这将使obj 成为您的事件对象。

标签: javascript jquery jquery-ui preventdefault


【解决方案1】:

您应该使用 jQuery 的侦听器来处理当前代码中未定义的事件。您还应该使用事件目标作为您的对象

/***This here**/
jQuery(document).on('change','#weightInput',test);
function test(event) {
        let obj = event.target
        var inputValue = parseInt($(obj).val());

        if (($(obj).val() < 0 || $(obj).val() > 100) && event.keyCode !== 46 // keycode for delete
            && event.keyCode !== 8 // keycode for backspace
        ) {
            event.preventDefault();
            $(obj).val(0);
        } else if (isNaN(inputValue)) {
            event.preventDefault();
            $(obj).val(0);
        }
}

【讨论】:

  • 我建议我使用 jQuery 方法而不是以下属性
【解决方案2】:

您需要将event 作为显式参数传递给onchange 参数。

您也不应该从$(function() { }) 调用它,因为那里没有任何事件。

function test(obj, event) {
  var inputValue = parseInt($(obj).val());
  if (($(obj).val() < 0 || $(obj).val() > 100) && event.keyCode !== 46 // keycode for delete
    &&
    event.keyCode !== 8 // keycode for backspace
  ) {
    event.preventDefault();
    $(obj).val(0);
  } else if (isNaN(inputValue)) {
    event.preventDefault();
    $(obj).val(0);
  }
}
<script src="https://code.jquery.com/ui/1.13.0/jquery-ui.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.0/jquery.min.js"></script>

<div>
  <input id="weightInput" type="number" class="form-control weightInput" data-key="" data-guid="" onchange="test(this, event)" value="" />
</div>

【讨论】:

  • 好吧,我忽略了将输入作为参数发送,谢谢
猜你喜欢
  • 2021-12-22
  • 2021-12-25
  • 2021-11-24
  • 2021-10-31
  • 2021-11-07
  • 2023-03-13
  • 2022-01-01
  • 2022-01-10
  • 1970-01-01
相关资源
最近更新 更多