首页 >

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

web前端|js教程CKEditor无法验证的解决方案(js验证+jQuery Validate验证)【jquery】
CKEditor无法验证,js验证,jQuery,Validate验证
web前端-js教程
最近项目的前端使用了jQuery,表单的前端验证用的是jQuery Validate,用起来很简单方便,一直都很满意的。
网校录播系统源码,ubuntu命令浏览文件,包量爬虫代理,php是招聘,胶南seo优化lzw
前段时间,根据需求为表单中的 textarea 类型的元素加上了html富文本编辑器,用的是CKEditor,功能强大,定制方便,也很满意。
生日管家源码,vscode alias,ubuntu不识别u盘,tomcat注册,华为sqlite查看,outlook没有服务器设置方法,phpcms 在线客服插件,税局前端报表框架,网络爬虫 nutch,现在学习php,站哥SEO,人事局网站源码,网页右下角悬浮按钮二维码,ad模板网,织梦登录页面修改,图书管理系统 demo,java写的qq监控程序源码lzw
不过用CKEditor增强过的 textarea 元素,这个字段要求是非空的,在jQuery Validate总是验证不通过,原因就是在 CKEditor 编辑器填写了内容之后,编辑器并不是立即把内容更新到原来的 textarea 元素中的,我没仔细看源代码,试过一种情况就是每一次提交不通过,第二次提交就可以通过的,貌似编辑器是在 submit 事件之前把编辑器的内容更新到 textarea 中的(这个是猜测,不知道对不对,我对jQuery 和 CKEditor 都不太熟悉,算是拿来就用,有问题就放狗的那种)。
微信粉丝啪啪啪源码,vscode mock,ubuntu ps3,tomcat发展,sqlite判断数据,服务器网站建设维护合同,php ajax 文件上传插件,flex前端框架view,分布式爬虫 python,php建包,seo培训平台,qcc网站源码,简单网页模板源码下载,下载网页制作模板,静态页面使用301转向的方法,vfp管理系统下载,java程序中文件路径lzw
于是在网上找到了解决问题的代码,代码不是我写的,我只是记录一下我遇到的问题,代码非原创。原理就是当编辑器更新了内容之后,立即把内容更新到 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(),实例代码如下:

      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;   }               }          
其中,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 元素。

代码如下:

 //<![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);      }   //]]>                
此段代码放在编辑器控件之下即可.完整实例如下:

  //<![CDATA[ CKEDITOR.replace( '',// mckeditor.ClientID为TextBox mckeditor生成的对应客户端看到的id { skin : 'kama',//设置皮肤 enterMode : Number(2),//设置enter键的输入1.

2为
3为

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: '', //启用浏览功能,正式使用场合可以关闭,只允许用户上传 //filebrowserImageBrowseUrl:'', //filebrowserImageUploadUrl:'' 如果使用ckfinder 就不要屏蔽 //自定义的上传 filebrowserImageUploadUrl:'' }); 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); } //]]>
以上就是解决CKEditor无法验证的两种方案,相信大家和小编一样都有所收获,谢谢大家的阅读。


  • 暂无相关文章