搜索

首页  >  问答  >  正文

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 这一点,为了一些指令你不得不整一些废标签出来。大家有什么想法?

漂亮男人漂亮男人2745 天前691

全部回复(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
  • 取消回复