javascript - 浏览器崩溃没有任何错误 - 原因
问题描述
我在服务器端使用 Google Application Script 编写应用程序,在客户端使用 MaterializeCSS + 纯 JavaScript。
我开始经历浏览器崩溃=blank
屏幕没有任何错误。只是一些警告
[Violation] 'click' handler took 1162ms
Unrecognized feature: 'ambient-light-sensor'.
Unrecognized feature: 'speaker'.
Unrecognized feature: 'vibrate'.
Unrecognized feature: 'vr'.
我把它缩小到这个按钮。注释掉的代码是原始代码。带有警报的只是用于调试。
<!-- <button id ="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="dotaceAdminDalsiSkolaFun()">
Přidat další školu</button> -->
<button id ="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="alert('testing')">
Přidat další školu</button>
现在,在某些情况下,我单击按钮然后单击“确定”以警告浏览器崩溃而没有错误但出现空白屏幕。该按钮位于 MaterlializeCSS 内部的表单中。
我创建了一个视频https://youtu.be/MiZehuumc4w以显示错误并非总是发生。只有在模态中填充了数据之后。如果模态保持为空。没有错误。
<!-- Dotace Modal Structure -->
<div id="dotaceModal" class="modal modal-fixed-footer">
<div class="modal-content">
<h4>Administrace dotací</h4>
<div class="row">
<form id= "dotaceModalForm" class="col s12">
<div class="row">
<div class="input-field col s6">
<input id="dotaceTitulek" name="dotaceTitulek" type="text" class="validate" data-field-name="" required>
<label class="active" for="dotaceTitulek">Název dotace</label>
</div>
<!-- <button id ="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="dotaceAdminDalsiSkolaFun()">Přidat další školu</button> -->
<button id ="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="alert('testing')">Přidat další školu</button>
</div>
<div id="dotaceSkolaKotva" data-counter="1"></div>
<div id="skolaClone1" class="row dotaceSkolaClone" data-counter="1" >
<div class="input-field col s12">
<input id="skolaName1" name="skolaName1" class="validate dotaceSkolaNameAutocomplete" type="text" data-counter="1" data-field-name="" autocomplete="off" onchange="session.autocomplete.currentDotaceIDCounter=this.dataset.counter">
<label class="active" for="skolaName1">Název školy</label>
</div>
<input id="dotaceSkolaID1" name="skolaID1" type="text" style="display:none">
</div>
<div class="row">
<div class="input-field col s12">
<input id="dotaceIdentifikace" name="dotaceIdentifikace" class="validate" type="text" data-field-name="" required>
<label class="active" for="dotaceIdentifikace">Identifikace dotace</label>
</div>
</div>
<input id="dotaceID" name="dotaceID" type="text" style="display:none">
</form>
</div>
</div>
<div class="modal-footer">
<a href="#!" class="modal-close waves-effect waves-green btn-flat" id="dotaceSmazat" style="float:left">Smazat</a>
<a href="#!" class="modal-close waves-effect waves-green btn-flat" id="dotaceZrusit">Zrušit</a>
<a href="#!" class="waves-effect waves-green btn-flat" id="dotaceUlozit" onclick="checkForm('dotaceModalForm')">Uložit</a>
</div>
</div>
有人可以建议发生了什么,如何调试和解决这个问题?
我在最新的 Chrome、Firefox、Vivaldi、Edge 和 Brave 上对其进行了测试。在私人模式下也没有任何浏览器扩展。所有测试用例的结果相同。
更新
因此,当元素button
位于form
模态框内时,就会出现问题。如果我把它放在外面它工作。有人可以解释一下吗?
解决方案
现在你有一个这样的按钮:
<button id="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="dotaceAdminDalsiSkolaFun()">Přidat další školu</button>
大概你在某处有一些代码 -
function dotaceAdminDalsiSkolaFun() {
// do stuff
}
稍微改变按钮中的 onclick 调用,将点击事件传递给函数:
<button id="dotaceAdminDalsiSkola" class="waves-effect btn" onClick="dotaceAdminDalsiSkolaFun(event)">Přidat další školu</button>
并在您的代码中,接收事件参数,并阻止该事件的默认行为(因此表单不提交)
function dotaceAdminDalsiSkolaFun(e) {
e.preventDefault();
// do stuff
}
推荐阅读
- python-3.x - Matplotlib- 在多色线子图下方添加一个颜色条,如图所示
- javascript - 如何在 Promise.all 中使用第一个 promise 的结果,以此类推
- python - 如何在python中的等高线图上绘制梯度向量
- docker - 在 Dockerfile 中链接 docker 容器
- c# - net core web api项目的类库中的依赖注入
- c# - C# 我的迷宫生成器似乎无法处理具有三个开放面的块
- php - symfony5 - 错误 500 页面而不是在树枝中形成错误
- python - 使用 Python 将每一列绘制为一行并按 Dataframe 每一列的第一行分组
- java - Java 扫描仪跳线
- wpf - WPF,ListBox逐项滚动到基于像素的滚动