如果您对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表单验证)
- 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表单验证)
您在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无法验证
对于全名验证,我这样做:
在您的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...
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验证)
最近项目的前端使用了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?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
最近项目的前端使用了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中也是一样: