GVKun编程网logo

Flutter FormField Validator无法验证(flutter表单验证)

17

如果您对FlutterFormFieldValidator无法验证感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于FlutterFormFieldValidator无法验证的

如果您对Flutter FormField Validator无法验证感兴趣,那么本文将是一篇不错的选择,我们将为您详在本文中,您将会了解到关于Flutter FormField Validator无法验证的详细内容,我们还将为您解答flutter表单验证的相关问题,并且为您提供关于AlertDialog中的TextFormField无法验证、AttributeError: Got AttributeError when attempting to get a value for field `password2` on serial...、CKEditor无法验证的解决方案(js验证+jQuery Validate验证)、CKEditor无法验证的解决方案(js验证+jQuery Validate验证)_jquery的有价值信息。

本文目录一览:

Flutter FormField Validator无法验证(flutter表单验证)

Flutter FormField Validator无法验证(flutter表单验证)

您在validator中拥有的FormField是在小部件构建上执行的,一个小技巧是改为使用validator中的TextFormField属性。


以您的代码为例添加了一个演示:

class InputTextWidget extends StatelessWidget {
  final String hintText;
  final TextInputType keyboardType;
  final TextInputAction keyboardAction;
  final TextEditingController inputController;
  final double height;
  final FormFieldValidator<String> validator;

  const InputTextWidget(
      {Key key,@required this.hintText,@required this.keyboardType,@required this.keyboardAction,@required this.inputController,this.validator,this.height = 50})
      : super(key: key);

  @override
  Widget build(BuildContext context) {
    return FormField(
      builder: (FormFieldState formFieldState) {
        return Column(
          crossAxisAlignment: CrossAxisAlignment.start,children: [
            Container(
              height: height,width: double.maxFinite,decoration: BoxDecoration(
                border: Border.all(),borderRadius: BorderRadius.all(
                  Radius.circular(8),),child: TextFormField(
                // new line
                validator: validator,// use validator in [TextFormField]
                // Notify the FormField State of Changes
                onChanged: (String value) {
                  formFieldState.didChange(value);
                },controller: inputController,style: TextStyle(fontSize: 14),keyboardType: keyboardType,textInputAction: keyboardAction,decoration:
                    InputDecoration.collapsed(hintText: hintText).copyWith(
                  hasFloatingPlaceholder: false,contentPadding: EdgeInsets.symmetric(
                    vertical: 15,horizontal: 10,// Show Form Field Error
            _showError(formFieldState),],);
      },);
  }

AlertDialog中的TextFormField无法验证

AlertDialog中的TextFormField无法验证

对于全名验证,我这样做:

在您的TextFormField中,验证程序尝试执行此类操作

validator: (value) {
  if (value.isEmpty) {

    // name is empty,don't validate
    return S.of(context).key('errorEmptyField');

  } else if (value.split(' ').length < 2) {

    // name contains only 1 word,don't validate
    return S.of(context).key('errorOnlyFirstName');

  } else if (value.length < 5) {

    // name is too short,don't validate
    return S.of(context).key('errorNameTooShort');

  }
  // validate
  return null;
},

我返回错误字符串以显示给用户,但是您可以返回布尔值或任何您想要的内容,无论如何这是基本的全名验证逻辑。

AttributeError: Got AttributeError when attempting to get a value for field `password2` on serial...

AttributeError: Got AttributeError when attempting to get a value for field `password2` on serial...

Error_msg:

AttributeError: Got AttributeError when attempting to get a value for field `password2` on serializer `        UserSerializer`.
        The serializer field might be named incorrectly and not match any attribute or key on the `User` instance.
        Original exception text was: ''User'' object has no attribute ''password2''.
        ERROR basehttp 124 "POST /users/ HTTP/1.1" 500 20189
        pydev debugger: process 22712 is connecting

问题:

  序列化器字段读写设置出错

解决:

  serializer中没有write_only_fields关键字, 需要在字段中加write_only=True

CKEditor无法验证的解决方案(js验证+jQuery Validate验证)

CKEditor无法验证的解决方案(js验证+jQuery Validate验证)

最近项目的前端使用了jQuery,表单的前端验证用的是jQuery Validate,用起来很简单方便,一直都很满意的。

前段时间,根据需求为表单中的 textarea 类型的元素加上了html富文本编辑器,用的是CKEditor,功能强大,定制方便,也很满意。

不过用CKEditor增强过的 textarea 元素,这个字段要求是非空的,在jQuery Validate总是验证不通过,原因就是在 CKEditor 编辑器填写了内容之后,编辑器并不是立即把内容更新到原来的 textarea 元素中的,我没仔细看源代码,试过一种情况就是每一次提交不通过,第二次提交就可以通过的,貌似编辑器是在 submit 事件之前把编辑器的内容更新到 textarea 中的(这个是猜测,不知道对不对,我对jQuery 和 CKEditor 都不太熟悉,算是拿来就用,有问题就放狗的那种)。

于是在网上找到了解决问题的代码,代码不是我写的,我只是记录一下我遇到的问题,代码非原创。原理就是当编辑器更新了内容之后,立即把内容更新到 textarea 元素。

CKEDITOR.instances["page_content"].on("instanceReady", function() 
    { 
            //set keyup event 
            this.document.on("keyup", updateTextArea); 
             //and paste event 
            this.document.on("paste", updateTextArea); 
 
    }); 
 
    function updateTextArea() 
    { 
        CKEDITOR.tools.setTimeout( function() 
              {  
                $("#page_content").val(CKEDITOR.instances.page_content.getData()); 
                $("#page_content").trigger(''keyup''); 
              }, 0);  
    } 

目前一切使用正常,算是解决了一个让我头痛的问题。

另一种解决思路:

CKEditor 编辑器是增强过的 textarea 元素,在填写了内容之后,编辑器并不立即把内容更新到原来的 textarea 元素中的,而是等到 submit 事件之前把编辑器的内容更新到 textarea 中.
因此,普通的js验证或是jquery validate验证都获取不到编辑器的值.)

1.js验证
获取CKEditor 编辑器的值其实很容易,其值就是CKEDITOR.instances.mckeditor.getData(),实例代码如下:

<script language="javascript" type="text/javascript">   
 
  function checkForm() 
       { 
         var f=document.form1; 
         var topicHeading=f.tbTopicHeading.value; 
         topicHeading = topicHeading.replace(/^\s+/g,""); 
         topicHeading = topicHeading.replace(/\s+$/g,""); 
                 if (topicHeading =="") 
                  { 
                    alert("请输入发表话题的标题."); 
                    f.tbTopicHeading.focus(); 
                    return false; 
                  } 
                  if(topicHeading.length>50); 
                  { 
                   alert("话题的主题长度必须在50字符以内."); 
                   f.tbTopicHeading.focus(); 
                   return false; 
                  } 
         var topicContent=CKEDITOR.instances.mckeditor.getData(); 
          
         topicContent = topicContent.replace(/^\s+/g,""); 
         topicContent = topicContent.replace(/\s+$/g,""); 
                 if (topicContent =="") 
                  { 
                    alert("请填写话题内容."); 
                    f.mckeditor.focus(); 
                    return false; 
                  }  
 
                  if(topicContent.length>4000) 
                  { 
                   alert("话题内容的长度必须在4000字符以内."); 
                   f.mckeditor.focus(); 
                   return false; 
                  }       
 
       }  
       </script> 

其中,mckeditor为编辑器的textarea的id和name.
ASP.NET中也是一样:

复制代码 代码如下:
<asp:TextBox ID="mckeditor" runat="server" TextMode="MultiLine" Width="94%" Height="400px" Css></asp:TextBox> 

2.jQuery Validate验证
jquery的验证模式不能直接使用CKEDITOR.instances.mckeditor.getData()这个值.
它是使用如下形式来提交验证:

function InitRules() { 
      opts = { 
         rules: 
         { 
            tbTopicHeading:{ 
            required:true, 
            maxlength:50   
          },           
          mckeditor:{ 
            required:true, 
            maxlength:4000 
          }  
         }, 
         messages: 
         { 
          tbTopicHeading:{ 
          required:"请输入发表话题的标题.", 
          maxlength:jQuery.format("话题的主题长度必须在50字符以内.")  
        }, 
          mckeditor:{ 
          required:"请填写话题内容.", 
          maxlength:jQuery.format("话题内容的长度必须在4000字符以内.")  
        } 
         }  
      } 
    } 

其中mckeditor为控件id,不仅有取值的作用,还有提示信息定位的作用.
因此,可以在页面加载时,加入实例化编辑器代码,实现编辑器更新了内容之后,立即把内容更新到 textarea 元素。

代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
CKEDITOR.instances["mckeditor"].on("instanceReady", function()    
    {    
            //set keyup event  
            this.document.on("keyup", updateTextArea);  
             //and paste event 
            this.document.on("paste", updateTextArea);   
    });    
 
    function updateTextArea()  
    {    
        CKEDITOR.tools.setTimeout( function() 
              {    
                $("#mckeditor").val(CKEDITOR.instances.mckeditor.getData());    
                $("#mckeditor").trigger(''keyup'');    
              }, 0);  
    }   
//]]> 
              </script> 

此段代码放在编辑器控件之下即可.完整实例如下:

<asp:TextBox ID="mckeditor" runat="server" TextMode="MultiLine" Width="98%" Height="400px" Css></asp:TextBox> 
<script type="text/javascript"> 
//<![CDATA[ 
CKEDITOR.replace( ''<%=mckeditor.ClientID %>'',// mckeditor.ClientID为TextBox mckeditor生成的对应客户端看到的id 
{ 
skin : ''kama'',//设置皮肤 
enterMode : Number(2),//设置enter键的输入1.<p>2为<br/>3为<div> 
shiftEnterMode : Number(1), // 设置shiftenter的输入 
disableNativeSpellChecker:false,  
scayt_autoStartup:false, 
toolbar_Full : [ 
[''Source'',''-'',''Save'',''NewPage'',''Preview'',''-''], 
[''Cut'',''Copy'',''Paste'',''PasteText'',''PasteFromWord'',''-''], 
[''Undo'',''Redo'',''-'',''Find'',''Replace'',''-'',''SelectAll'',''RemoveFormat''], 
[''NumberedList'',''BulletedList'',''-'',''Outdent'',''Indent''], 
[''JustifyLeft'',''JustifyCenter'',''JustifyRight'',''JustifyBlock''], 
[''Link'',''Unlink'',''Anchor''], 
[''Image'',''Table'',''HorizontalRule''],[''Subscript'',''Superscript''], 
''/'', 
[''Bold'',''Italic'',''Underline''], 
[''TextColor'',''BGColor''], 
[''Styles'',''Format'',''Font'',''FontSize''] 
], 
//filebrowserBrowseUrl: ''<%=ResolveUrl("~/ckfinder/ckfinder.html")%>'', //启用浏览功能,正式使用场合可以关闭,只允许用户上传 
//filebrowserImageBrowseUrl:''<%=ResolveUrl("~/ckfinder/ckfinder.html?Type=Images")%>'', 
//filebrowserImageUploadUrl:''<%=ResolveUrl("~/ckfinder/core/connector/aspx/connector.aspx?command=QuickUpload&type=Images")%>'' 如果使用ckfinder 就不要屏蔽 
//自定义的上传 
filebrowserImageUploadUrl:''<%=ResolveUrl("~/fileupload/fileupload.aspx?command=QuickUpload&type=Images")%>'' 
}); 
CKEDITOR.instances["mckeditor"].on("instanceReady", function()  
    { 
            //set keyup event 
            this.document.on("keyup", updateTextArea);  
             //and paste event 
            this.document.on("paste", updateTextArea);  
    });  
 
    function updateTextArea() 
    { 
        CKEDITOR.tools.setTimeout( function()  
              { 
                $("#mckeditor").val(CKEDITOR.instances.mckeditor.getData());  
                $("#mckeditor").trigger(''keyup'');  
              }, 0);  
    }   
//]]> 
              </script> 

以上就是解决CKEditor无法验证的两种方案,相信大家和小编一样都有所收获,谢谢大家的阅读。

您可能感兴趣的文章:
  • JS操作Fckeditor的一些常用方法(获取、插入等)
  • javascript获取ckeditor编辑器的值(实现代码)
  • FCKeditorAPI 手册 js操作获取等
  • fckeditor常用Js,获取fckeditor内容,统计fckeditor字数,向fckeditor写入指定代码
  • javascript fckeditor编辑器取值与赋值实现代码
  • FCKEditor常用Js代码,获取FCK内容,统计FCK字数,向FCK写入指定代码
  • FCKeditor提供了一个完整的JavaScript API
  • JavaScript 使用Ckeditor+Ckfinder文件上传案例详解

CKEditor无法验证的解决方案(js验证+jQuery Validate验证)_jquery

CKEditor无法验证的解决方案(js验证+jQuery Validate验证)_jquery

最近项目的前端使用了jquery,表单的前端验证用的是jquery validate,用起来很简单方便,一直都很满意的。

前段时间,根据需求为表单中的 textarea 类型的元素加上了html富文本编辑器,用的是CKEditor,功能强大,定制方便,也很满意。

不过用CKEditor增强过的 textarea 元素,这个字段要求是非空的,在jQuery Validate总是验证不通过,原因就是在 CKEditor 编辑器填写了内容之后,编辑器并不是立即把内容更新到原来的 textarea 元素中的,我没仔细看源代码,试过一种情况就是每一次提交不通过,第二次提交就可以通过的,貌似编辑器是在 submit 事件之前把编辑器的内容更新到 textarea 中的(这个是猜测,不知道对不对,我对jQuery 和 CKEditor 都不太熟悉,算是拿来就用,有问题就放狗的那种)。

于是在网上找到了解决问题的代码,代码不是我写的,我只是记录一下我遇到的问题,代码非原创。原理就是当编辑器更新了内容之后,立即把内容更新到 textarea 元素。

CKEDITOR.instances["page_content"].on("instanceReady", function() 
    { 
            //set keyup event 
            this.document.on("keyup", updateTextArea); 
             //and paste event 
            this.document.on("paste", updateTextArea); 
 
    }); 
 
    function updateTextArea() 
    { 
        CKEDITOR.tools.setTimeout( function() 
              {  
                $("#page_content").val(CKEDITOR.instances.page_content.getData()); 
                $("#page_content").trigger(''keyup''); 
              }, 0);  
    } 
登录后复制

目前一切使用正常,算是解决了一个让我头痛的问题。

另一种解决思路:

CKEditor 编辑器是增强过的 textarea 元素,在填写了内容之后,编辑器并不立即把内容更新到原来的 textarea 元素中的,而是等到 submit 事件之前把编辑器的内容更新到 textarea 中.
因此,普通的js验证或是jquery validate验证都获取不到编辑器的值.)

1.js验证
获取CKEditor 编辑器的值其实很容易,其值就是CKEDITOR.instances.mckeditor.getData(),实例代码如下:

<script language="javascript" type="text/javascript">   
 
  function checkForm() 
       { 
         var f=document.form1; 
         var topicHeading=f.tbTopicHeading.value; 
         topicHeading = topicHeading.replace(/^\s+/g,""); 
         topicHeading = topicHeading.replace(/\s+$/g,""); 
                 if (topicHeading =="") 
                  { 
                    alert("请输入发表话题的标题."); 
                    f.tbTopicHeading.focus(); 
                    return false; 
                  } 
                  if(topicHeading.length>50); 
                  { 
                   alert("话题的主题长度必须在50字符以内."); 
                   f.tbTopicHeading.focus(); 
                   return false; 
                  } 
         var topicContent=CKEDITOR.instances.mckeditor.getData(); 
          
         topicContent = topicContent.replace(/^\s+/g,""); 
         topicContent = topicContent.replace(/\s+$/g,""); 
                 if (topicContent =="") 
                  { 
                    alert("请填写话题内容."); 
                    f.mckeditor.focus(); 
                    return false; 
                  }  
 
                  if(topicContent.length>4000) 
                  { 
                   alert("话题内容的长度必须在4000字符以内."); 
                   f.mckeditor.focus(); 
                   return false; 
                  }       
 
       }  
       </script> 
登录后复制

其中,mckeditor为编辑器的textarea的id和name.
ASP.NET中也是一样:

复制代码 代码如下:

2.jQuery Validate验证
jquery的验证模式不能直接使用CKEDITOR.instances.mckeditor.getData()这个值.
它是使用如下形式来提交验证:

function InitRules() { 
      opts = { 
         rules: 
         { 
            tbTopicHeading:{ 
            required:true, 
            maxlength:50   
          },           
          mckeditor:{ 
            required:true, 
            maxlength:4000 
          }  
         }, 
         messages: 
         { 
          tbTopicHeading:{ 
          required:"请输入发表话题的标题.", 
          maxlength:jQuery.format("话题的主题长度必须在50字符以内.")  
        }, 
          mckeditor:{ 
          required:"请填写话题内容.", 
          maxlength:jQuery.format("话题内容的长度必须在4000字符以内.")  
        } 
         }  
      } 
    } 
登录后复制

其中mckeditor为控件id,不仅有取值的作用,还有提示信息定位的作用.
因此,可以在页面加载时,加入实例化编辑器代码,实现编辑器更新了内容之后,立即把内容更新到 textarea 元素。

代码如下:

<script type="text/javascript"> 
//<![CDATA[ 
CKEDITOR.instances["mckeditor"].on("instanceReady", function()    
    {    
            //set keyup event  
            this.document.on("keyup", updateTextArea);  
             //and paste event 
            this.document.on("paste", updateTextArea);   
    });    
 
    function updateTextArea()  
    {    
        CKEDITOR.tools.setTimeout( function() 
              {    
                $("#mckeditor").val(CKEDITOR.instances.mckeditor.getData());    
                $("#mckeditor").trigger(''keyup'');    
              }, 0);  
    }   
//]]> 
              </script> 
登录后复制

此段代码放在编辑器控件之下即可.完整实例如下:

<asp:TextBox ID="mckeditor" runat="server" TextMode="MultiLine" Width="98%" Height="400px" Css></asp:TextBox> 
<script type="text/javascript"> 
//<![CDATA[ 
CKEDITOR.replace( ''<%=mckeditor.ClientID %>'',// mckeditor.ClientID为TextBox mckeditor生成的对应客户端看到的id 
{ 
skin : ''kama'',//设置皮肤 
enterMode : Number(2),//设置enter键的输入1.<p>2为<br/>3为<div> 
shiftEnterMode : Number(1), // 设置shiftenter的输入 
disableNativeSpellChecker:false,  
scayt_autoStartup:false, 
toolbar_Full : [ 
[''Source'',''-'',''Save'',''NewPage'',''Preview'',''-''], 
[''Cut'',''Copy'',''Paste'',''PasteText'',''PasteFromWord'',''-''], 
[''Undo'',''Redo'',''-'',''Find'',''Replace'',''-'',''SelectAll'',''RemoveFormat''], 
[''NumberedList'',''BulletedList'',''-'',''Outdent'',''Indent''], 
[''JustifyLeft'',''JustifyCenter'',''JustifyRight'',''JustifyBlock''], 
[''Link'',''Unlink'',''Anchor''], 
[''Image'',''Table'',''HorizontalRule''],[''Subscript'',''Superscript''], 
''/'', 
[''Bold'',''Italic'',''Underline''], 
[''TextColor'',''BGColor''], 
[''Styles'',''Format'',''Font'',''FontSize''] 
], 
//filebrowserBrowseUrl: ''<%=ResolveUrl("~/ckfinder/ckfinder.html")%>'', //启用浏览功能,正式使用场合可以关闭,只允许用户上传 
//filebrowserImageBrowseUrl:''<%=ResolveUrl("~/ckfinder/ckfinder.html&#63;Type=Images")%>'', 
//filebrowserImageUploadUrl:''<%=ResolveUrl("~/ckfinder/core/connector/aspx/connector.aspx&#63;command=QuickUpload&type=Images")%>'' 如果使用ckfinder 就不要屏蔽 
//自定义的上传 
filebrowserImageUploadUrl:''<%=ResolveUrl("~/fileupload/fileupload.aspx&#63;command=QuickUpload&type=Images")%>'' 
}); 
CKEDITOR.instances["mckeditor"].on("instanceReady", function()  
    { 
            //set keyup event 
            this.document.on("keyup", updateTextArea);  
             //and paste event 
            this.document.on("paste", updateTextArea);  
    });  
 
    function updateTextArea() 
    { 
        CKEDITOR.tools.setTimeout( function()  
              { 
                $("#mckeditor").val(CKEDITOR.instances.mckeditor.getData());  
                $("#mckeditor").trigger(''keyup'');  
              }, 0);  
    }   
//]]> 
              </script> 
登录后复制

以上就是解决CKEditor无法验证的两种方案,相信大家和小编一样都有所收获,谢谢大家的阅读。

关于Flutter FormField Validator无法验证flutter表单验证的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于AlertDialog中的TextFormField无法验证、AttributeError: Got AttributeError when attempting to get a value for field `password2` on serial...、CKEditor无法验证的解决方案(js验证+jQuery Validate验证)、CKEditor无法验证的解决方案(js验证+jQuery Validate验证)_jquery的相关信息,请在本站寻找。

本文标签:

上一篇删除所有未下载的文件AVAssetDownloadTask(删除所有未安装的软件)

下一篇javascript / jquery脚本来计算html页面大小(js计算页面高度)