bzm*_*zmw 5 javascript localization parsley.js
目前我正在使用
data-parsley-`constraint`-message="English sentence goes here"
Run Code Online (Sandbox Code Playgroud)
但现在我正在努力添加本地化,这些消息将永远不会使用i18n库进行翻译,因为它们是自定义的.
有没有办法添加类似的东西
data-parsley-`constraint`-message-fr="Francais francais francais"
Run Code Online (Sandbox Code Playgroud)
或者通过JS来做到这一点?
具体来说,我正在使用data-parsley-required-message =""
Luí*_*ruz 13
为什么不使用Parsley的本地化而不是在输入上定义消息?
我建议您从源代码下载所需的本地化版本.之后,根据文档,您可以在插件之前加载i18n,如下所示:
<script src="i18n/fr.js"></script>
<script src="i18n/it.js"></script>
<script src="parsley.min.js"></script>
<script type="text/javascript">
window.ParsleyValidator.setLocale('fr');
</script>
Run Code Online (Sandbox Code Playgroud)
或者你可以在插件之后加载i18n(在这种情况下,它将假设最后加载的本地化 - 在下面的示例中它将是意大利语),如下所示:
<script src="parsley.min.js"></script>
<script src="i18n/fr.js"></script>
<script src="i18n/it.js"></script>
Run Code Online (Sandbox Code Playgroud)
在我的项目中,我通常根据Cookie或Session变量加载所需的本地化:
<script src="parsley.min.js"></script>
<script src="i18n/"<?= echo $lang ?>".js"></script>
Run Code Online (Sandbox Code Playgroud)
使用其中任何一个选项,您无需为每个输入添加data-parsley- constraint-ssssage.当您需要更改消息时,您可以在本地化文件中执行此操作.
总之,如果您需要自定义验证器,可以查看文档以了解如何定义不同的本地化.
这通过更改插件的源代码来解决OP的需要
您可以在parsley.js中编辑一个名为_getErrorMessage(第1264行,带有2.0.4)的方法,如下所示:
_getErrorMessage: function (fieldInstance, constraint) {
var customConstraintErrorMessage = constraint.name + 'Message';
if ('undefined' !== typeof fieldInstance.options[customConstraintErrorMessage])
return window.ParsleyValidator.formatMessage(fieldInstance.options[customConstraintErrorMessage], constraint.requirements);
return window.ParsleyValidator.getErrorMessage(constraint);
},
Run Code Online (Sandbox Code Playgroud)
对于这样的事情:
_getErrorMessage: function (fieldInstance, constraint) {
//added
var locale = window.ParsleyValidator.locale;
var namespace = fieldInstance.options.namespace;
var customConstraintErrorMessage = namespace + constraint.name + '-' + locale;
if (fieldInstance.$element.attr(customConstraintErrorMessage)) {
// treat parameters
if (fieldInstance.$element.attr(customConstraintErrorMessage).indexOf("%s") !== -1)
return window.ParsleyValidator.formatMessage(fieldInstance.$element.attr(customConstraintErrorMessage), constraint.requirements);
return fieldInstance.$element.attr(customConstraintErrorMessage);
}
// original
var customConstraintErrorMessage = constraint.name + 'Message';
if ('undefined' !== typeof fieldInstance.options[customConstraintErrorMessage])
return window.ParsleyValidator.formatMessage(fieldInstance.options[customConstraintErrorMessage], constraint.requirements);
return window.ParsleyValidator.getErrorMessage(constraint);
},
Run Code Online (Sandbox Code Playgroud)
有了这个,你可以在输入直接指定信息,使用sintax 数据parsley- constraint- locale.这是一个示例:
<input type="text" name="name" value="" data-parsley-required="true"
data-parsley-required-en="Name is required"
data-parsley-required-pt="O nome é obrigatório" />
<input type="number" name="phone" value=""
data-parsley-minlength="9"
data-parsley-minlength-en="Phone length must be equal to %s"
data-parsley-minlength-pt="O telefone deverá ter %s digitos" />
Run Code Online (Sandbox Code Playgroud)
当您需要使用某种约束时(在上面的示例中,有data-parsley-minlength哪些是变量),您可以使用%s消息内部.这将替换为正确的值.
在将parsley绑定到表单之前,您需要设置要使用的语言环境(注意:您需要包含相对于您正在使用的语言环境的javascript文件,否则您将收到类似的错误Error: pt is not available in the catalog):
window.ParsleyValidator.setLocale('pt');
$("#myForm").parsley();
Run Code Online (Sandbox Code Playgroud)
这是一个示范的jsfiddle.如果您想测试,只需setLocale('en')查看英文消息即可.