如果用户上传文件,它将调用createArray(data)
函数,然后显示单选按钮。此后,如果用户选择了单选按钮,则它会警告用户选择了哪个按钮,但是onchange
功能不起作用TT。我尝试了几种不同的方法,但是没有用。
我的单选按钮为var字符串格式,并使用.innerHTML
。
function createArray(data) {
if (data !== null && data !== "" && data.length > 1) {
this.CSVdata = data;
document.getElementById("message").innerHTML = " File upload successful with" + ((CSVdata.length) - 1) + " records!";
var radioHtml = "<div style='padding: 15px; width:100; height: 300;'><br>";
radioHtml += "<form id='mybutton'>"
radioHtml += "<p><b>Please select one of the following choice, and run one of the graph in the View menu</b></p><br>"
radioHtml += "<input type='radio' name='radiobut' id ='avgwages'/> AvgWages (Bar, Line) <br> "
radioHtml += "<input type='radio' name='radiobut' id ='estpopulation'/> EstimatedPopulation (Bar, Line)<br>"
radioHtml += " <input type='radio' name='radiobut' id ='state'/> State (Bar, Pie,Line) <br>";
radioHtml += "</form>";
radioHtml += "</div>";
document.getElementById("dataselection").innerHTML = radioHtml;
} else {
document.getElementById("message").innerHTML = " Cannot upload File!";
}
};
$("#mybutton").on('change', 'input[name=radiobut]:checked', function() {
alert("change");
});
两者都在document.ready
函数内部。
答案 0 :(得分:1)
在动态添加元素时,需要像下面那样全局地处理它的事件。
$(document).on('change','#mybutton',function(){
alert("change");
});
如果您正在使用change
管理id
事件,则无需在change
事件函数中传递其他参数。
尝试以下解决方案。
$("#mybutton").on('change',function(){
alert("change");
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="radio" id="mybutton" />
答案 1 :(得分:0)
请检查以下代码段的完美解决方案 正是您想要的:
(function() {
$('input[type=radio][name=radiobut]').change(function() {
alert("Changed: " + this.id);//selected radio ID
});
})();
(function() {
$('input[type=radio][name=radiobut]').change(function() {
alert("Changed: " + this.id);//selected radio ID
});
})();
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div style='padding: 15px; width:100; height: 300;'><br>
<form id='mybutton'>
<p><b>Please select one of the following choice, and run one of the graph in the View menu</b></p><br>
<input type='radio' name='radiobut' id ='avgwages'/> AvgWages (Bar, Line) <br>
<input type='radio' name='radiobut' id ='estpopulation'/> EstimatedPopulation (Bar, Line)<br>
<input type='radio' name='radiobut' id ='state'/> State (Bar, Pie,Line) <br>
</form>
</div>