我试图弄清楚为什么我动态添加的输入块(在表格的单元格内)不会触发日期时间选择器。我提供了一个概念验证代码块来演示这个问题。如果您按原样运行此代码,默认输入标签 (id: dti1) 会完美运行,并且会弹出日期时间选择器并允许用户选择日期和时间。但是,当您单击“添加另一个”时,日期时间选择器不会在新的输入元素上弹出,即使它正确显示并正确关联了 dtpick 类。我的假设是日期时间选择器与页面加载时的每个 dtpick 类元素相关联,所以这就是日期时间选择器不起作用的原因。当我动态添加行时,有什么方法可以强制发生这种情况?
<html>
<head>
<!-- includes: jquery, jquery_ui_datepicker, timepicker-- references removed here-->
<script>
$(document).ready(function(){
$('.dtpick').datetime({
userLang : 'en',
americanMode: true});
});
function addItem()
{
var t = document.getElementById('myTable');
var row = t.insertRow(-1);
var c1 = row.insertCell(0);
var c1content=document.createElement("input");
c1content.setAttribute("type","text");
c1content.setAttribute("name","dtnew");
c1content.setAttribute("id","dtinew");
c1content.setAttribute("class","dtpick");
c1content.setAttribute("value","2011-08-20 01:00:00");
c1.appendChild(c1content);
}
</script>
</head>
<body>
<table id="myTable">
<tr>
<td><b>Row Header:</b></td>
</tr>
<tr>
<td><input type="text" name="dt1" id="dti1" class="dtpick" value="2011-08-21 01:00:00"></td>
</table><br>
<a onclick="addItem()"> Add another</a>
</body>
</html>
非常感谢任何帮助!
大卫