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

angularjs – 角度服务

发布时间:2020-12-17 17:20:12 所属栏目:安全 来源:网络整理
导读:我试图在角度控制器之间共享一个id 我创建了如下服务: app.factory("idService",function() { var id; addId = function(id) { id = id; }; getId = function() { return id; }; }); 在我的控制器中,我试图使用此服务如下: app.controller('photoFormContr
我试图在角度控制器之间共享一个id

我创建了如下服务:

app.factory("idService",function() {
    var id;
    addId = function(id) {
        id = id;
    };
    getId = function() {
        return id;
    };    
});

在我的控制器中,我试图使用此服务如下:

app.controller('photoFormController',['$scope','$http','idService',function($scope,$http,idService) {

       $scope.id = idService.getId();
}]);

我收到一个错误,无法调用未定义的方法,显然我注入了错误的服务.有人可以帮忙吗?

编辑:

根据下面的解决方案,该服务不再生成错误,但是我无法恢复id变量,我可以看到它是从一个控制器设置的,但在检索时它仍未定义:

app.factory("idService",function() {
    var id;
    addId = function(id) {
        id = id;
        console.log("added id of: " + id);
    };
    getId = function() {
        console.log("trying to return : " + id);
        return id;
    };
    return {
        addId: addId,getId: getId
    };
});

解决方法

您需要在工厂内返回一个对象.返回的对象是您的服务实例:

app.factory("idService",function() {
    var _id; //use _id instead to avoid shadowing your variable with the same name id
    var addId = function(id) { //use var to avoid creating a property on the global object
        _id = id;
    }; 
    var getId = function() { //use var to avoid creating a property on the global object
        return _id;
    };    

    return {
        addId : addId,getId : getId 
    };
});

(编辑:李大同)

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

    推荐文章
      热点阅读