首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用angularjs工厂?

如何使用angularjs工厂?
EN

Stack Overflow用户
提问于 2013-10-21 15:21:00
回答 1查看 533关注 0票数 1
代码语言:javascript
复制
   var myappWebApp = angular.module('myappWebApp', ['ui.bootstrap']);

//工厂

代码语言:javascript
复制
myappWebApp.factory('wired', function () {

    this.currOp = false;

    return {
        currOp1 : this.currOp
    }
});

   // controller

myappWebApp.controller('wiredCtrl',
    function ($scope, $http, wired) {

        //data
        $scope.currOp = wired.currOp;//why is this undefined?
        $scope.currOpInText = wired.currOpInText();
        $scope.altOpInText = null;
        $scope.boxA = null;
....

我的scope.currOp如何总是自动具有与wired.currOp相同的值?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-10-21 15:39:19

如果你只是在复制一个bool,你就不能。布尔值是按值复制的,所以你不会得到基于引用的更新。

您可以考虑使用带有布尔值的对象:

代码语言:javascript
复制
myappWebApp.factory('wired', function () {

    this.state = { curOp: false };

    return {
        state: this.state
    }
});

然后,当您在范围中引用它时,您可以这样做:

代码语言:javascript
复制
myappWebApp.controller('wiredCtrl',
    function ($scope, $http, wired) {

    $scope.opState = wired.state;
});

现在,当curOp发生变化时,控制器将发生更改。您可以监视更改:

代码语言:javascript
复制
$scope.$watch("opState.curOp", function(newVal, oldVal) {
    // Handle changes in curOp
});

或者你可以绑定到它上:

代码语言:javascript
复制
CurOp: {{state.currOp}}

备注:您问的:“为什么这是未定义的?”答案是因为您的服务公开了currOp1,但是您正在引用currOp

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19498470

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档