Jor*_*rre 4 forms validation jquery ckeditor
我在 textarea 和 jQuery 验证插件(http://bassistance.de/jquery-plugins/jquery-plugin-validation/)上使用 CKEditor
使用 jQuery 插件可以将字段标记为空或必需。当“产品名称”等字段为空时,提交表单时该字段将被标记为无效。
但是,在输入“产品名称”时,该字段将在输入时自动标记为有效。太好了,但我想对启用 CKEditor 的 textarea 也有同样的效果。使用纯文本区域一切正常(输入文本时,该字段变为有效),但是在将 CKEditor 添加到文本区域后,这不再起作用。
从那时起,您必须在 CKEditor textarea 重新验证之前单击提交按钮。
关于如何使这项工作有任何想法?
更新:
我尝试了您给我的线程中的解决方案,但它不起作用: 使用 jQuery 从 CKEditor 的 iframe 中获取内容
我有:
CKEDITOR.instances["page_content"].document.on('keydown', function(event)
{
CKEDITOR.tools.setTimeout( function()
{
$("#page_content").val(CKEDITOR.instances.page_content.getData());
}, 0);
});
Run Code Online (Sandbox Code Playgroud)
但这一直给我:“CKEDITOR.instances.page_content.document 未定义”
我的 textare 的 id 是“page_content”
单击按钮后这可以正常工作,但是正如您所见,我需要以某种方式触发 keydown 事件
$("#btnOk").click(function(event) {
CKEDITOR.instances.page_content.updateElement(); //works fine
});
Run Code Online (Sandbox Code Playgroud)
更新 2:
这段代码是正确的,它将数据从 CKEDITOR 获取到我的 textarea 中,但是,我的验证插件仍然没有发生任何事情,它在 CKEDitor 中没有“在我输入时做出响应”,而它应该做出反应并说该字段在我输入时正常输入一些文字
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());
}, 0);
}
Run Code Online (Sandbox Code Playgroud)
jquery 验证插件对 textarea 或文本字段中的 keyup 事件做出反应,因此您需要在更新 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);
}
Run Code Online (Sandbox Code Playgroud)