对于新建的元素,onchange函数只调用一次
onchange function is called only once for newly create element
函数创建一个元素并将其附加到父元素。有问题的元素包含其他元素,其中有一个输入复选框。我为onchange事件添加了一个事件侦听器。为了简洁起见,侦听器只向控制台写入"here"。第一次加载页面时,"here"消息出现,这是有意义的,因为checked属性设置为true。问题是,在此之后的任何单击都不会触发侦听器。有人能阐明这一点吗?
function createNewRow(number){
var row=document.createElement('div');
automaticLegend.appendChild(row);
var txt=document.createTextNode('Particle '+number);
var showBtn=document.createElement('input');
showBtn.type='checkbox';
showBtn.checked=true;
var labelShow=document.createTextNode('Show ');
var traceBtn=document.createElement('input');
traceBtn.type='checkbox';
traceBtn.checked=true;
var labelTrace=document.createTextNode('Trace ');
var radiusBtn=document.createElement('input');
radiusBtn.type='checkbox';
radiusBtn.checked=true;
var labelRadius=document.createTextNode('Radius ');
var delBtn=document.createElement('input');
delBtn.type='button';
delBtn.value='Remove';
row.appendChild(txt);
row.appendChild(showBtn);
row.appendChild(labelShow)
row.appendChild(traceBtn);
row.appendChild(labelTrace);
row.appendChild(radiusBtn);
row.appendChild(labelRadius);
row.appendChild(delBtn);
showBtn.onchange=resetShowFlag(showBtn);
};
function resetShowFlag(el){
console.log('here');
}
尝试使用这个。showBtn.addEventListener('change',resetShowFlag);
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量