Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/user-interface/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何使用angularjs工厂?_Javascript_Angularjs - Fatal编程技术网

Javascript 如何使用angularjs工厂?

Javascript 如何使用angularjs工厂?,javascript,angularjs,Javascript,Angularjs,//工厂 var myappWebApp = angular.module('myappWebApp', ['ui.bootstrap']); 我的scope.currOp如何始终自动具有与wired.currOp相同的值?如果只是复制一个bool,则不能。布尔值是按值复制的,因此不会得到基于引用的更新 您可以考虑使用布尔型对象: myappWebApp.factory('wired', function () { this.currOp = false; retur

//工厂

   var myappWebApp = angular.module('myappWebApp', ['ui.bootstrap']);

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

如果只是复制一个bool,则不能。布尔值是按值复制的,因此不会得到基于引用的更新

您可以考虑使用布尔型对象:

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;
....
然后,当您在范围中引用它时,您可以执行以下操作:

myappWebApp.factory('wired', function () {

    this.state = { curOp: false };

    return {
        state: this.state
    }
});
现在,当
curOp
发生变化时,控制器将发生变化。您可以监视更改:

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

    $scope.opState = wired.state;
});
或者您可以绑定到它:

$scope.$watch("opState.curOp", function(newVal, oldVal) {
    // Handle changes in curOp
});
注意:您问:“为什么这是未定义的?”答案是因为您的服务公开了
currOp1
,但您引用的是
currOp

CurOp: {{state.currOp}}