parsley.js不验证几次验证
parsley.js do not validate several validations
我已经编写了一些代码来验证文本区域,但它不适用于一个 CKeditor 文本区域的多次验证。这是我的代码:
<div id="insdescription" class="col-md-12 input-group" >
<textarea type="text" id="insdescription1" name="insdescription" class="form-control" rows="5" data-parsley-errors-container="#insdescription-errors" data-parsley-required-message="Это поле необходимо!" data-parsley-minlength-message="Введите не менее 10 символов!" ><?= $instructors['description']; ?></textarea>
<script>
CKEDITOR.replace('insdescription1');
</script>
</div>
<div id="insdescription-errors"></div>
<script type="text/javascript">
CKEDITOR.on('instanceReady', function () {
$('#insdescription1').attr('minlength', '10');
$('#insdescription1').attr('required', '', );
$.each(CKEDITOR.instances, function (instance) {
CKEDITOR.instances[instance].on("change", function (e) {
for (instance in CKEDITOR.instances) {
CKEDITOR.instances[instance].updateElement();
$('form').parsley().validate();
}
});
});
});
</script>
实际上,它适用于 required="" 验证。但它不适用于 minlength="10"。这是截图
您需要创建自己的 Parsley 自定义验证器。
确实,您正在验证 CKEDITOR 的内容,例如,字符串:
1234
变为:
<p>1234</p>
最后一个字符串比 4 长。
自定义验证器可以是:
window.Parsley.addValidator('minTextSize', {
validateString: function(_value, minTextSize, parsleyInstance) {
if (!window.FormData) {
alert('You are making all developpers in the world cringe. Upgrade your browser!');
return true;
}
var txt = $(_value).text().trim();
return txt.length > minTextSize;
},
requirementType: 'integer'
});
因此,您的文本区域将是:
<textarea id="insdescription1" name="insdescription" class="form-control" rows="5"
data-parsley-trigger="keyup"
data-parsley-min-text-size="10"
data-parsley-errors-container="#insdescription-errors"
data-parsley-required-message="Это поле необходимо!rrr"
data-parsley-min-text-size-message="Введите не менее 10 символов!xxx"></textarea>
fiddle是here。
PS: 我在你的消息末尾添加了字符,因为我听不懂你的语言,我需要测试。
我已经编写了一些代码来验证文本区域,但它不适用于一个 CKeditor 文本区域的多次验证。这是我的代码:
<div id="insdescription" class="col-md-12 input-group" >
<textarea type="text" id="insdescription1" name="insdescription" class="form-control" rows="5" data-parsley-errors-container="#insdescription-errors" data-parsley-required-message="Это поле необходимо!" data-parsley-minlength-message="Введите не менее 10 символов!" ><?= $instructors['description']; ?></textarea>
<script>
CKEDITOR.replace('insdescription1');
</script>
</div>
<div id="insdescription-errors"></div>
<script type="text/javascript">
CKEDITOR.on('instanceReady', function () {
$('#insdescription1').attr('minlength', '10');
$('#insdescription1').attr('required', '', );
$.each(CKEDITOR.instances, function (instance) {
CKEDITOR.instances[instance].on("change", function (e) {
for (instance in CKEDITOR.instances) {
CKEDITOR.instances[instance].updateElement();
$('form').parsley().validate();
}
});
});
});
</script>
实际上,它适用于 required="" 验证。但它不适用于 minlength="10"。这是截图
您需要创建自己的 Parsley 自定义验证器。
确实,您正在验证 CKEDITOR 的内容,例如,字符串:
1234
变为:
<p>1234</p>
最后一个字符串比 4 长。
自定义验证器可以是:
window.Parsley.addValidator('minTextSize', {
validateString: function(_value, minTextSize, parsleyInstance) {
if (!window.FormData) {
alert('You are making all developpers in the world cringe. Upgrade your browser!');
return true;
}
var txt = $(_value).text().trim();
return txt.length > minTextSize;
},
requirementType: 'integer'
});
因此,您的文本区域将是:
<textarea id="insdescription1" name="insdescription" class="form-control" rows="5"
data-parsley-trigger="keyup"
data-parsley-min-text-size="10"
data-parsley-errors-container="#insdescription-errors"
data-parsley-required-message="Это поле необходимо!rrr"
data-parsley-min-text-size-message="Введите не менее 10 символов!xxx"></textarea>
fiddle是here。
PS: 我在你的消息末尾添加了字符,因为我听不懂你的语言,我需要测试。