您的位置:首页 > 编程语言 > PHP开发

phpcms v9中formvalidator无法验证时间插件返回的数据解决办法

2013-06-27 10:33 253 查看
在phpcms中,会引用formvalidator来验证表单,会用 Dynarch Calendar来做时间插件,但是当这两种结合起来的时候,就会出现一个问题

问题是这样的,当选择input时间框的时候,弹出日期选择层,选择完之后, Dynarch Calendar会把时间数值直接赋值给被点击的input框,但是这个input框不会获得焦点,所以在不获得焦点的时候formvalidator就无法验证时间数据,就会造成,明明已经选择了时间,但是formvalidator还是提示,时间未添加。

在找解决办法的时候,发现Dynarch Calendar官网介绍说,这个插件有一个函数叫onchange,于是我就从这个函数下手,在onchange的时候,给input框一个focus(),在添加完之后,又发现一个问题,这样写的话,在chrome中没问题,但是在ie8中会报错,因为我一个页面当中有多个日期选择,有一些是display:none的状态,这样的话,ie8中会报错。所以我就又修改了下代码

代码如下,代码所在文件在phpcms/libs/classes/form.class.php 208行附近添加

$str .= '<script type="text/javascript">
Calendar.setup({
weekNumbers: '.$showweek.',
inputField : "'.$id.'",
trigger    : "'.$id.'",
dateFormat: "'.$format.'",
showTime: '.$showsTime.',
minuteStep: 1,
onSelect   : function() {this.hide();},
onChange : function (cal){
try
{
document.getElementById("'.$id.'").focus();
}
catch(err)
{

}
}
});

</script>';


这样的话,就解决了在ie和chrome中formvalidator无法验证的问题。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐