CKEditor无法验证的解决方案(js验证+jQuery Validate验证)
来源: 阅读:841 次 日期:2016-07-02 11:49:00
温馨提示: 小编为您整理了“CKEditor无法验证的解决方案(js验证+jQuery Validate验证)”,方便广大网友查阅!

这篇文章主要为大家详细介绍了CKEditor无法验证的解决方案和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" CssClass="ckeditor"></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" CssClass="ckeditor"></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无法验证的两种方案,相信大家和小编一样都有所收获

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map