无论如何要禁用dojo日期文本框的客户端验证?

时间:2008-08-19 01:51:47

标签: javascript dojo

在下面的示例中,我使用的是dijit.form.DateTextBox

<input type="text" name="startDate" dojoType="dijit.form.DateTextBox" constraints="{datePattern:'MM/dd/yyyy'}"  value='<c:out value="${sessionScope.adminMessageForm.startDate}"/>' />

因此,例如,如果用户开始在日期中输入“asdf”,则字段变为黄色,并显示弹出错误消息The value entered is not valid.。即使我删除constraints="{datePattern:'MM/dd/yyyy'}"它仍然有效。

如果没有详细说明原因,我希望能够保留dojoType并在特定情况下仍然阻止验证。

3 个答案:

答案 0 :(得分:6)

尝试覆盖标记中的validate方法。

这将起作用(刚刚测试过):

<input type="text" name="startDate" dojoType="dijit.form.DateTextBox" 
  constraints="{datePattern:'MM/dd/yyyy'}"  
  value='<c:out value="${sessionScope.adminMessageForm.startDate}"/>'
  validate='return true;'
/>

答案 1 :(得分:1)

我唯一的建议是以编程方式删除服务器端或客户端的dojoType。不可能保留dojoType而不进行验证。除非您创建自己的类型,其中包含逻辑。

答案 2 :(得分:1)

我遇到了类似的问题,ValidationTextBox满足了我的所有需求,但是必须先禁用验证例程,直到用户第一次按下Submit。

我的解决方案是使用几个新方法将其克隆到ValidationConditionalTextBox中:

    enableValidator:function() {
        this.validatorOn = true;
    },

    disableValidator: function() {
        this.validatorOn = false;
    },

然后 - 在验证器:function()中我添加了一个检查:

        if (this.validatorOn)
        { ... }

相当简单,我的validatorOn的默认值为false(这显示在javascript的顶部)。当我的表单提交时,只需调用enableValidator()。您可以在此处查看完整的JavaScript:

http://lilawnsprinklers.com/js/dijit/form/ValidationTextBox.js