jquery动态添加代码,引入的日历插件不能用。

如题,而且我用live方法有个很严重的bug。就是我直接点我绑定的input框没反应,但是我点其他的input框两次后,再回来点就能触发出来。求解。<script>$(f... 如题,
而且我用live方法有个很严重的bug。
就是我直接点我绑定的input框没反应,但是我点其他的input框两次后,再回来点就能触发出来。
求解。

<script>
$(function(){
$("[name=arrival_time]").live('click',function(){
$(this).datepicker({
dateFormat : 'yy-mm-dd',
//dayNames : ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
//dayNamesShort : ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
dayNamesMin : ['日','一','二','三','四','五','六'],
monthNames : ['一月','二月','三月','四月','五月','六月','七月','八月','九月','十月','十一月','十二月'],
monthNamesShort : ['一','二','三','四','五','六','七','八','九','十','十一','十二'],
altField : '#abc',
altFormat : 'dd/mm/yy',
// appendText : '日历',
// showWeek : true,
// weekHeader : '周',
firstDay : 1,
// disabled : true,
changeMonth :true,
changeYear : true,
maxDate :"",//这个控制今天以后的日期是否可选
// minDate :0,
yearRange : '1950:2020',
// minDate:-1m
});
})

})
</script>
html代码
<tr>
<th style="width:30%;">到达时间:</th>
<td style="width:70%">
<input class="ss" type="text" readonly="readonly" name="arrival_time" value="">
</td>
</tr>
到达时间会有很多。我到时候要动态加新的。但是新加的就是我前面说的那个问题。
展开
 我来答
lsyuan_hello
2014-12-25 · TA获得超过1691个赞
知道小有建树答主
回答量:663
采纳率:0%
帮助的人:694万
展开全部
live 的 click 事件里面绑定了datepicker函数,即点击文本框的时候才绑定datepicker,你当然要点两次。一般datepicker控件只需要绑定一次就行了,即:$(this).datepicker({...}); 这样就行了。
你如果有多个需要添加,可以包装一个函数,文本框控件作为参数,类似:
function bindpicker(obj)
{
$(obj).datepicker({});

}

执行了datepicker,就不需要再live click 了

可以试试 :)
追问
我要动态生成很多input,新生成的绑定不了我才用的live。有什么什么办法谢谢
追答
动态生成input的时候如果有ID,就传入bindpicker函数中绑定时间控件;
如果没有ID,最好生成一个ID,生成ID是最佳最简单的办法

如果实在没有ID,就通过循环
$.each('[name=arrival_time]',function(idx,con){
$(con).datepicker({});

});

循环的时候要避免重复绑定,可能你还需要借助一个数组放置已绑定的input;

也可以考虑用jquery 动态创建文本框,类似:
var newinput = $("",{

type:'text',

val:'text',

function:function(){

$(this).addClass('active');

}

});

newinput.datepicker({});

$('input的父容器').append(newinput);
jghdream
2014-12-25 · TA获得超过374个赞
知道小有建树答主
回答量:321
采纳率:91%
帮助的人:283万
展开全部
直接用bind的就可以
追问
我现在是能点出来,但是就像我说的
bug在这里。
就是我直接点我绑定的input框没反应,但是我点其他的input框两次后,再回来点就能触发出来。
求解。
追答
这个是逻辑问题,你把加载datepicker的代码拿到click事件外面去,应该这也写:
添加个ID

$("#timer").datepicker({
dateFormat : 'yy-mm-dd',
//dayNames : ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
//dayNamesShort : ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
dayNamesMin : ['日','一','二','三','四','五','六'],
monthNames : ['一月','二月','三月','四月','五月','六月','七月','八月','九月','十月','十一月','十二月'],
monthNamesShort : ['一','二','三','四','五','六','七','八','九','十','十一','十二'],
altField : '#abc',
altFormat : 'dd/mm/yy',
// appendText : '日历',
// showWeek : true,
// weekHeader : '周',
firstDay : 1,
// disabled : true,
changeMonth :true,
changeYear : true,
maxDate :"",//这个控制今天以后的日期是否可选
// minDate :0,
yearRange : '1950:2020',
// minDate:-1m
});
})

这样就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式