Czy jest sposób na pobranie aktualnie używanego języka w kontrolerze (bez $translateProvider
)?
Nie udało się znaleźć niczego w $translate
serwisie.
Czy jest sposób na pobranie aktualnie używanego języka w kontrolerze (bez $translateProvider
)?
Nie udało się znaleźć niczego w $translate
serwisie.
Odpowiedzi:
$translate.use()
jest geterem i ustawiaczem.
Zobacz to demo znalezione w linkach do dokumentów:
$translate.use()
jest droga do zrobienia. Ponadto, gdy wykonywany jest program ładujący asynchroniczny, możesz chcieć użyć, $translate.proposedLanguage()
który zwraca klucz języka, który jest aktualnie załadowany, ale nie został jeszcze załadowany.
$translate.use()
nie został ustawiony. $translate.proposedLanguage()
dał mi właściwy język.
$translate.proposedLanguage()
w app.config? mam tylko $ translateProvider i muszę znaleźć wynik tej funkcji w config, a nie później w kontrolerze. Masz pomysł ?
proposedLanguage()
Podczas korzystania z angular-translate-loader-static-files zauważyłem, że $translate.proposedLanguage()
powracało to undefined
podczas używania domyślnego języka, podczas gdy $translate.use()
zawsze zwracało proponowany język.
Dlatego naprawiłem to za pomocą:
var currentLang = $translate.proposedLanguage() || $translate.use();
$translate
Usługa ma metodę zwaną preferredLanguage()
że zwrot tego, co chcesz. Zwrotem tej funkcji jest ciąg języka, np. „En”.
Tutaj napisałem ci przykład:
angular.module('traslateApp').controller('myController', ['$scope', '$translate', function($scope,$translate){
$scope.changeLanguage = function (langKey) {
$translate.use(langKey);
};
$scope.getCurrentLanguage = function () {
$translate.preferredLanguage();
};
}])
Myślę, że to lepszy sposób na określenie języka -
$window.navigator.language || $window.navigator.userLanguage
Może nie jest powiązany, ale może być przydatny. W angular2 + sposobem na dostęp do aktualnego języka jest
...
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" }
I użycietranslate
filtru w widok jak zwykle, na przykład:<video controls poster="img/poster-{{ 'LANG_CODE' | translate }}.png"> […] </video>