- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 HTML
...
<div class="content-row"><div class="col-md-4"></div>
<div class="col-md-4">
<form>
<div id='undiv' class="form-group"><label for="uname">Name:</label><input id="uname" type="text" class="form-control"/></div>
<div class="form-group"><label for="email">Email (optional):</label><input id="email" type="text" class="form-control" /></div>
<div class="form-group"><label for="gamecode">Game Code:</label><input id="gamecode" type="text" class="form-control" /></div>
<div class="form-group pull-right"><input id="join" type="button" value="Join" class="btn btn-primary btn-lg btn btn-primary btn-lg" /></div>
</form>
</div><div class="col-md-4"></div>
</div>
....
body
中 HTML 下方的 Javascript
<script type='text/javascript'>
var uname = document.getElementById("uname");
var email = document.getElementById("email");
var gamecode = document.getElementById("gamecode");
var joinbtn = document.getElementById("join");
var notify = document.getElementById("notify");
var undiv = document.getElementById("undiv");
...
uname.addEventListener("blur",function(evt) {
console.log('onblur');
var un = uname.value;
console.log(un);
if(un.length >= 2) {
undiv.className += " has-success has-feedback";
undiv.innerHTML += '<span id="mark" class="glyphicon glyphicon-ok form-control-feedback" aria-hidden="true"></span>';
}
else {
undiv.className += " has-error has-feedback";
undiv.innerHTML += '<span id="mark" class="glyphicon glyphicon-remove form-control-feedback" aria-hidden="true"></span>';
}
//uname.value = un;
});
uname.addEventListener("focus",function(evt) {
console.log('onfocus');
undiv.className = "form-group";
var mark = document.getElementById("mark");
if(mark !=null) {
mark.parentNode.removeChild(mark);
console.log("mark="+mark);
}
});
</script>
onfocus
和 onblur
事件上的 uname
只触发一次。
我在按钮点击事件
上有另一个eventListener
,它工作正常。
我不明白为什么 focus
和 blur
eventListeners
不会在事件发生时触发?
Chrome 和 Firefox 上的调试器没有显示任何错误或警告...而且我不明白出了什么问题?
最佳答案
一个好的做法是在你的 table 上放一把尺子,如果你发现自己在打字 element.innerHTML += "..."
,就拿起尺子拍打你的手背.
;-)
说真的,在 .innerHTML
之后使用 +=
是非常具有破坏性和不必要的,正如您所看到的会导致意想不到的结果。
另一个答案显示了如何使用 DOM 创建方法来实现,这是一个好方法,但是如果您想使用 HTML
标记,请使用 .insertAdjacentHTML()
而不是 .innerHTML
。
uname.addEventListener("blur",function(evt) {
console.log('onblur');
var un = uname.value;
console.log(un);
if(un.length >= 2) {
undiv.className += " has-success has-feedback";
undiv.insertAdjacentHTML("beforeend", '<span id="mark" class="glyphicon glyphicon-ok form-control-feedback" aria-hidden="true"></span>');
}
else {
undiv.className += " has-error has-feedback";
undiv.insertAdjacentHTML("beforeend", '<span id="mark" class="glyphicon glyphicon-remove form-control-feedback" aria-hidden="true"></span>');
}
//uname.value = un;
});
您会注意到第一个参数是 "beforeend"
,第二个是您的 HTML。 .insertAdjacentHTML()
方法接受四个不同的字符串作为第一个参数。它们如下:
“beforebegin”
(将标记放在元素之前)"afterbegin"
(将标记放在元素的开头)"beforeend"
(将标记放在最后的元素内)"afterend"
(将标记放在元素之后)因此相对于调用该方法的元素,有四个位置可以插入 HTML。这些不会破坏任何现有元素,这就是它比 .innerHTML
更好的原因。
关于Javascript AddEventListener 只触发一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28441798/
我想在按下按钮时打开一个表单,然后在完成表单后创建另一个按钮以将数据存储在对象中。 我这样做了,但在第二个 addEventListener 中它给了我这个错误: cannot read proper
这是我实际代码的简化版本。 有三个复选框和按钮(每个编号为 0、1、2)和一个提交按钮。简而言之,如果您选中复选框编号 1 和 2,单击提交,按钮 1 和 2 将被着色。现在您可以单击任何彩色按钮,它
问题代码 var el = document.getElementById("searchcharm_'"+touch_id+"'"); el.addEventListener('click',
window.document.addEventListener = function(event) {...} window.addEventListener = function(event) {
这段代码块有什么区别: var xhr = new XMLHttpRequest(); xhr.upload.addEventListener("progress", uploadProgress,
在使用 PhoneGap 时,它有一些使用 document.addEventListener 的默认 JavaScript 代码,但我有自己的代码使用 window.addEventListener
当我运行这段代码时,为什么 .body 事件先触发? document.addEventListener('click', function() { console.log('The docume
我将带有循环的 addEventListener 添加到一些 anchor 元素 products 中,如下所示: for(var j=0;j
所以我的代码可以按我想要的方式工作,但是大多数(IE 除外)调试器都会向我抛出此错误: 未捕获类型错误:无法读取未定义的属性“addEventListener” 这是代码: //Get all ele
我真的不知道为什么这不起作用。在我的 HTML 中,如果我将脚本放在 head 部分,我会在控制台中收到以下错误: Uncaught TypeError: Cannot read property '
在 React 中,当你有一个带有 onClick 属性的元素时,很容易使用 Enzyme 的 .simulate("click") 方法来点击它。然而,在我的代码库中有一个示例,其中一个元素被 Re
问候,由于某种原因,当我单击按钮时,我的 -addEventListener 没有执行。任何人都可以帮忙这是我的代码: function elNegro() { alert("Thank Yo
我正在将我的一些代码从 onClick 更改为 addEventListener,因为我已经阅读了各种好处,并且出于关注点分离的目的。然而,我遇到的问题之一是,虽然使用 onClick,我能够调用一个
我正在尝试向我在循环中生成的某些元素添加事件监听器。我必须使用 div.lastChild - 虽然在这个例子中它非常愚蠢。但这只是演示: var func = function() {
我在将事件监听器添加到 JS 时遇到问题...如果我将按钮与 onclick 属性连接,它会起作用,但如果我在 HTML 中删除它并尝试添加 eventListener('click', myFunc
我不知道为什么,但是当我点击“按钮”时什么也没有发生... 控制台中没有消息,没有错误。如何解决? JS var bird = (function(){ let button = doc
我正在绘制一个方框网格,希望能够单击每个方框并使用 SocketIO 将带有其 ID 的通知发送到服务器 let boxes = document.querySelecto
我想是新手问题。 以下代码是我在文档就绪时调用的函数的一部分。它旨在在鼠标移动时永久返回当前鼠标位置的值。 正在发生的奇怪事情:在文档就绪时移动鼠标不会将任何内容记录到控制台。我知道 mouse_mo
我是 Flash 的新手,我似乎无法完成这个简单的操作。 (我正在使用 ActionScript 3.0) 我在我的编辑器中创建了一个输入文本框。实例名称是“测试”。在我的 Action 编辑器中,我
我有一个像 那些标签包含一些内容,我想打开/关闭它们,但仅使用纯 javascript。我已经尝试过使用 document.querySelectorAll
我是一名优秀的程序员,十分优秀!