搜尋

首頁  >  問答  >  主體

angular.js - angular-translate 有條件輸出詞條有什麼好方法?

最近公司產品要做多語言支持,用了 angular-translate 來做,基本上還算順利。

然後就碰到有的模板裡是這樣寫的:

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

很顯然,filter 沒法直接用了,目前是用 ngIf 把它改寫了,類似這樣:

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

但是如果不想有多餘的 span 呢?有時候就是挺煩 Angular 這一點,為了一些指令你不得不整一些廢標籤出來。大家有什麼想法?

漂亮男人漂亮男人2775 天前705

全部回覆(4)我來回復

  • 淡淡烟草味

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

    雷雷

    回覆
    0
  • 黄舟

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

    樓主也許可以嘗試用一個controller方法來實現,例如:

    <!-- 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);
        }
    };
    

    這樣雖然html裡的冗餘減少了, 但是程式碼量增加。

    回覆
    0
  • 为情所困

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

    這麼寫的一定是校長!

    回覆
    0
  • 天蓬老师

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

    好高深啊

    回覆
    0
  • 取消回覆