加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Angularjs 1.3异步过滤器无法正常工作

发布时间:2020-12-17 06:50:56 所属栏目:安全 来源:网络整理
导读:我有以下代码,它基本上通过服务中的$http.get请求从服务器加载消息,然后在i18n过滤器中使用.过滤器工作正常,角度版本1.2.24,但更新到1.3.5后,它不再有效. 我想知道是否有人遇到过类似的问题,并且可以对此有所启发. var module = angular.module('myApp',[]).
我有以下代码,它基本上通过服务中的$http.get请求从服务器加载消息,然后在i18n过滤器中使用.过滤器工作正常,角度版本1.2.24,但更新到1.3.5后,它不再有效.

我想知道是否有人遇到过类似的问题,并且可以对此有所启发.

var module = angular.module('myApp',[])

.factory('MessageFactory',function ($http,$locale,$log) {
    var messages = {};

    $http.get("/i18n/" + $locale.id + "/list",{cache: true}).success(function(data) {
        $log.debug("Getting messages for",$locale.id);
        messages = data;
    });

    return {
        getMessage: function (key) {
            return messages[key];
        }
    }
})

.filter('i18n',function (MessageFactory) {
    return function (key) {
        return MessageFactory.getMessage(key);
    }
});

Html代码

<h2>{{'message.page.title'|i18n}}</h2>

解决方法

经过几个小时的挖掘,我改变了

.filter('i18n',function (MessageFactory) {
    return function (key) {
        return MessageFactory.getMessage(key);
    }
});

.filter('i18n',function (MessageFactory) {
    function filterFn(key) {
        return MessageFactory.getMessage(key);
    }

    filterFn.$stateful = true;

    return filterFn;
});

注意filterFn.$stateful这就是诀窍.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读