我有一个Rails应用程序,我使用Redactor进行富文本输入。表单放在Bootstrap模式中。我希望在用户键入时验证(在线状态),并在字段为空时显示验证错误。我正在使用BootstrapValidator作为验证部分。我目前没有收到redactor
文本区域的任何验证消息。
代码的相关部分如下所示:
= form_for idea, remote: remote, html: {role: :form, "data-model" => 'idea', multipart: true} do |f|
# This field / validation works
.form-group
= f.label :title, "Title", :class => "required"
= f.text_field :title, :class => "form-control"
# This does not
.form-group
= f.label :description, :class => "required"
= f.text_area :description, :class => "form-control big-text-area redactor"
Javascript看起来像这样:
:javascript
$('#new_idea').bootstrapValidator({
message: 'This value is not valid',
feedbackIcons: {
valid: 'fa fa-check-square',
invalid: 'fa fa-warning',
validating: 'fa fa-circle-o-notch spin'
},
fields: {
"idea[title]": {
validators: {
notEmpty: {
message: 'The title is required'
}
}
},
"idea[description]": {
validators: {
callback: {
message: 'The idea description is required',
callback: function(value, validator) {
# NOTE: This part of the code never get called
var code = $('[name="idea[description]"]').code();
return (code !== '' && code !== '<p><br></p>');
}
}
}
}
}
})
$('.redactor').redactor({
keyupCallback: function (e) {
validateEditor();
}
});
function validateEditor() {
$('#new_idea').bootstrapValidator('revalidateField', "idea[description]");
};
关于如何使验证工作的任何想法?
答案 0 :(得分:1)
我在使用Redactor时碰到了类似的东西,所以这可能会有所帮助。在我的情况下,我在Redactor绑定的textarea上有一个更改侦听器(类似于我认为Bootstrap Validator正在做的事情)但问题是Redactor正在吃更改事件原来的textarea。为了解决这个问题,我在初始化Redactor插件时实现了以下功能。
var $mytextarea = $('selector-for-textarea');
$mytextarea.redactor({
changeCallback: function( html ) {
$mytextarea.trigger( 'change' );
}
});
希望这会有所帮助,欢呼。