cari

Rumah  >  Soal Jawab  >  teks badan

angular.js - angular-translate Adakah terdapat cara yang baik untuk mengeluarkan istilah secara bersyarat?

Baru-baru ini, produk syarikat perlu menyokong sokongan berbilang bahasa, dan terjemahan sudut digunakan untuk melakukannya, yang pada asasnya lancar.

Kemudian saya terjumpa beberapa templat yang berkata:

{{gender ? '男' : '女'}}

Jelas sekali, filter tidak boleh digunakan secara langsung pada masa ini, ia ditulis semula menggunakan ngIf, serupa dengan ini:

<span ng-if="gender">{{'common.male' | translate}}</span>
<span ng-if="!gender">{{'common.female' | translate}}</span>

Tetapi bagaimana jika anda tidak mahu tambahan span? Kadang-kadang saya jengkel dengan aspek Angular ini Anda perlu membersihkan beberapa tag yang tidak berguna untuk beberapa arahan. Apakah pendapat anda?

漂亮男人漂亮男人2775 hari yang lalu707

membalas semua(4)saya akan balas

  • 淡淡烟草味

    淡淡烟草味2017-05-15 16:51:10

    <span>{{ (gender?'common.male':'common.female') | translate}}</span>
    

    balas
    0
  • 黄舟

    黄舟2017-05-15 16:51:10

    Poster mungkin cuba menggunakan kaedah pengawal untuk mencapainya, seperti:

    <!-- template file -->
    <span ng-bind="showGender(gender)"></span>
    
    // angular controller
    app.controller('MyCtrl', function ($scope, $filter)) {
        $scope.showGender = function (gender) {
            return $filter('filter_name')(gender);
        }
    };
    

    Dengan cara ini, walaupun redundansi dalam html dikurangkan, jumlah kod meningkat.

    balas
    0
  • 为情所困

    为情所困2017-05-15 16:51:10

    Orang yang menulis ini mestilah pengetua!

    balas
    0
  • 天蓬老师

    天蓬老师2017-05-15 16:51:10

    Sangat mendalam

    balas
    0
  • Batalbalas