加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 如何使用angular-translate动态翻译输入文本(datep

发布时间:2020-12-17 07:01:36 所属栏目:安全 来源:网络整理
导读:我正在使用angular-translate为我的应用程序提供i18n,我能够正确翻译标签,按钮文本等. 我面临的问题是当我尝试根据所选语言区域设置更改日期时.日期从日期选择器中选择. 日期被选入输入元素: input type="text" class="form-control" required="" ng-model=
我正在使用angular-translate为我的应用程序提供i18n,我能够正确翻译标签,按钮文本等.
我面临的问题是当我尝试根据所选语言区域设置更改日期时.日期从日期选择器中选择.

日期被选入输入元素:

<input type="text" class="form-control" required="" ng-model="date" placeholder="{{ 'DATE_PLACEHOLDER' | translate }}" translate="{{ 'select_date'|translate:{date:date} }}"/>

占位符转换工作正常,但是当我更改语言时,日期格式没有发生变化.
我创建了一个描述当前场景的plunkr.

Plunker Link

请建议一种方法,我可以在其中翻译插入的值或表单中的文本.
此外,我想知道如何在加载页面之前克服键值的闪烁.

解决方法

>添加意大利语语言环境,我从 http://forum.html.it/forum/showthread/t-2912577.html复制它:

$.fn.datepicker.dates['it'] = {
  days: ["Domenica","Lunedì","Martedì","Mercoledì","Giovedì","Venerdì","Sabato","Domenica"],daysShort: ["Dom","Lun","Mar","Mer","Gio","Ven","Sab","Dom"],daysMin: ["Do","Lu","Ma","Me","Gi","Ve","Sa","Do"],months: ["Gennaio","Febbraio","Marzo","Aprile","Maggio","Giugno","Luglio","Agosto","Settembre","Ottobre","Novembre","Dicembre"],monthsShort: ["Gen","Feb","Apr","Mag","Giu","Lug","Ago","Set","Ott","Nov","Dic"],today: "Oggi",clear: "Cancella",weekStart: 1,format: "dd/mm/yyyy"
};

>将语言代码的转换映射从en_EN格式添加到en:

// language codes convertor map
var convertorMap = {
  'en_US': 'en','it_IT': 'it'
};

>在您的语言切换器功能中,删除当前的日期选择器并使用新语言初始化新的日期选择器,确保以新格式更新日期:

$scope.switchLanguage = function (key) {
  var dp = $('#datePicker');
  // get current date
  var currentDate = dp.datepicker('getDate');

  // update datepicker with new locale
  dp.datepicker('remove');
  dp.datepicker({
    autoclose: true,language: convertorMap[key]
  });
  // restore current date according to the new locale
  dp.datepicker('update',currentDate);

  $translate.use(key);
};

>要仅在翻译准备就绪时显示视图,请将您的包装元素(我使用< body>)更改为:

<body ng-controller="Ctrl" class="ng-hide" ng-show="showView">
  .....
</body>

并在您的控制器中:

// will be fired when the service is "ready" to translate (i.e. loading 1st language)
$translate.onReady(function () {
  $scope.showView = true;
});

>关于jQuery datepicker的ng-model指令什么都不做,所以我删除了它,并将ng-model更新代码添加到初始datepicker函数:

$('#datePicker').datepicker({
  autoclose: true
})
// update ng model
.on('changeDate',function(e) {
  $timeout(function () {
    $scope.date = $('#datePicker').datepicker('getUTCDate');
  });
});

如果您在控制台消息中看到如下消息:

pascalprecht.translate.$translateSanitization: No sanitization strategy has been configured. This can have serious security implications.

据说将在下一版本中修复:https://github.com/taigaio/taiga-front/issues/778

plunker:http://plnkr.co/edit/EGtHPG?p=preview

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读