Existe uma maneira de obter o idioma usado atualmente em um controlador (sem $translateProvider
)?
Não foi possível encontrar nada no $translate
serviço.
Existe uma maneira de obter o idioma usado atualmente em um controlador (sem $translateProvider
)?
Não foi possível encontrar nada no $translate
serviço.
Respostas:
$translate.use()
é um getter e setter.
Veja esta demonstração encontrada nos links dos documentos:
$translate.use()
é o caminho a percorrer. Além disso, quando um carregador assíncrono é executado, você pode querer usar o $translate.proposedLanguage()
que retorna a chave de idioma do idioma que está carregado atualmente, mas ainda não terminou de carregar.
$translate.use()
não foram definidas. $translate.proposedLanguage()
me deu o idioma correto.
$translate.proposedLanguage()
em app.config? eu só tenho $ translateProvider e preciso encontrar o resultado dessa função IN config, não mais tarde no controlador. Você tem alguma ideia ? Muito obrigado
proposedLanguage()
Ao usar angular-translate-loader-static-files, percebi que $translate.proposedLanguage()
retornava undefined
ao usar o idioma padrão, mas $translate.use()
sempre retornava o idioma proposto.
Portanto, eu corrigi usando:
var currentLang = $translate.proposedLanguage() || $translate.use();
O $translate
serviço possui um método chamado preferredLanguage()
que retorna o que você deseja. O retorno desta função é a string da linguagem, como 'en'.
Aqui, eu escrevi um exemplo para você:
angular.module('traslateApp').controller('myController', ['$scope', '$translate', function($scope,$translate){
$scope.changeLanguage = function (langKey) {
$translate.use(langKey);
};
$scope.getCurrentLanguage = function () {
$translate.preferredLanguage();
};
}])
Acho que esta é a melhor maneira de determinar o idioma -
$window.navigator.language || $window.navigator.userLanguage
Talvez não esteja relacionado, mas pode ser útil. No angular2 + a forma de acessar o idioma atual é
...
import { TranslateService } from '@ngx-translate/core';
export class MyComponent implements OnInit {
constructor(private translate: TranslateService) {}
ngOnInit() {
translate.use('it');
const currentLang = this.translate.currentLang;
}
}
{ "LANG_CODE": "en" }
e usar otranslate
filtro no veja como de costume, como:<video controls poster="img/poster-{{ 'LANG_CODE' | translate }}.png"> […] </video>