javascript - 为什么动态创建的单选按钮没有触发事件监听器

标签 javascript html loops event-listener

这里是一个简单测验应用程序的一些代码。一个对象数组用于存储问题、选项和正确答案。每个问题都有四个可能的答案,存储在一个数组中。对于这四个选项,我创建了四个动态输入单选元素。四个输入单选元素中的每一个都分配有一个事件监听器。但不知何故,事件监听器没有触发。这可能是什么原因? 为了方便起见,我给出了实际问题所在的部分:

 var setQues=(function(){

            var index=0;
            var span=document.createElement('span');
            span.setAttribute('style','color:crimson;font-weight:20px;');
            span.setAttribute('id','myspan');
            var div=document.getElementById('mydiv');
            var btn=document.getElementById('btn');


            return function (){
                div.innerHTML='';
                span.innerHTML=ques[index].title;
                div.appendChild(span);
                div.innerHTML+='</br>';
                ques[index].option.forEach(function(el,indx,arr){
                var input=document.createElement('input');
                input.setAttribute('type','radio');
                input.setAttribute('name','question');
                input.setAttribute('id',ques[index].option[indx]);

                input.value=el;
                div.appendChild(input);

                var label=document.createElement('label');
                label.setAttribute('for',ques[index].option[indx]);
                label.innerHTML=el;


                div.appendChild(label);
                input.addEventListener('change',function(e){

                    alert(this);

                });
                div.innerHTML+='</br>';

             });

             (index < ques.length-1) ? (btn.value='next',index++) : (btn.value='start quiz again',index=0);


            }})()

          document.getElementById('btn').addEventListener('click',setQues);

完整代码:

var ques=[
          {
		    title:'who is the captain of bangladesh odi team?',
		    option:['mashrafee','tamim','sakib','mushfic'],
		    crctAns:'mashrafee'
		  },
		  {
		    title:'who invented ac current?',
		    option:['nicola tesla','tomas edison','henry ford','graham bell'],
		    crctAns:'nicola tesla'
		  },
		  {  
		    title:'who starred in "TRAINING DAY" movie?',
		    option:['danzel washington','morgan freeman','lionerdo decaprio','chirstian bell'],
		    crctAns:'danzel washington'
		  }
		  ];
		  var setQues=(function(){
		  
		    var index=0;
		    var span=document.createElement('span');
			span.setAttribute('style','color:crimson;font-weight:20px;');
			span.setAttribute('id','myspan');
			var div=document.getElementById('mydiv');
			var btn=document.getElementById('btn');
			
		   
			return function (){
			    div.innerHTML='';
			    span.innerHTML=ques[index].title;
			    div.appendChild(span);
				div.innerHTML+='</br>';
			    ques[index].option.forEach(function(el,indx,arr){
			    var input=document.createElement('input');
			    input.setAttribute('type','radio');
				input.setAttribute('name','question');
				input.setAttribute('id',ques[index].option[indx]);
				
			    input.value=el;
				div.appendChild(input);
				
				var label=document.createElement('label');
				label.setAttribute('for',ques[index].option[indx]);
				label.innerHTML=el;
				   
				
				div.appendChild(label);
				input.addEventListener('change',function(e){
				
				    alert(this);
					
				});
				div.innerHTML+='</br>';
				
			 });
			 
			 (index < ques.length-1) ? (btn.value='next',index++) : (btn.value='start quiz again',index=0);
			 
			   
			}})()
		  
		  document.getElementById('btn').addEventListener('click',setQues);
  #mydiv{
	   background:lightblue;
	   border:1px solid skyblue;
	   width:200px;
	   height:200px;
	   box-shadow:-5px 0px  
	   
	}
	input[type="button"]{
	   cursor:pointer;
	}
	input[type='radio']{
	   cursor:pointer;
	}
	label:hover{
	   cursor:pointer;
	}
<h1>quiz</h1>
<div id='mydiv' ></div>
<input type='button' value='start quiz' id='btn'>

最佳答案

解决方案

JSFiddle:http://jsfiddle.net/7q81sfd0/15/

尝试在将子级附加到 DOM 之前添加事件监听器,但没有成功。在所有单选按钮都附加到 DOM 后,诉诸循环。

var inputRadio = document.getElementsByTagName('input');
for(var i = 0; i < inputRadio.length; i++) {
    if(inputRadio[i].type === "radio")
    {
        inputRadio[i].onchange = function() {
            console.log("clicked "+this.value);
        };                
    }
}

关于javascript - 为什么动态创建的单选按钮没有触发事件监听器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27857958/

相关文章:

javascript - HTML5 canvas ctx.fillText 不会换行?

javascript - 来自文件 JQuery/javascript 的警报文本

c - 坚持退出 C 中的循环

Java - 循环到平均 rgb 值应该会破坏事物....但不是

c++ - 需要帮助在循环/数组程序 C++ 中显示值

javascript - Node.js 检查名称是否与掩码匹配

javascript - 无法在 firebase 上上传数据?

html - 按钮不会随 div 中的 block 级文本移动

javascript - 知道一个好的 jQuery 日期选择器(某种)插件吗?

javascript - 理解 Typescript 编译器生成的 Javascript