1

我在我的应用程序中使用 ng-init 来初始化一个变量。问题是我在加载应用程序后更改此变量,并且我希望我首先初始化的变量在函数执行后存储新值。我是角度新手,无法弄清楚...

这是我的ng-init

<tr ng-repeat="(script_id, cron_format) in row" **ng-init**="oldCron = cron_format">
    <td>{{user_id}}</td>
    <td>{{script_id}}</td>
    <td>
       <input type="text" ng-model="cron_format" ng-blur="saveCron(user_id,script_id,cron_format,oldCron)"/>
    </td>
</tr>

并且saveCron()应该更改 的值oldCron,但是每次我调用该函数时,它都会使用 ng-init 中的值初始化 oldCron。这是我尝试提交更改的功能:

$scope.saveCron = function(userId,scriptId,cronFormat,oldCron){
    if (oldCron != cronFormat) {
        oldCron = cronFormat;
        $http.post("updateCronChange.php",cron_format=" + cronFormat, function (data) {
            alert('cron format changed to:' + cronFormat);
        });
    }
}

知道如何oldCron在第一次初始化后更新和忽略 ng-init 吗?

4

1 回答 1

1

我们无法满足您的要求,因为ng-init在呈现 HTML 时会被调用。

我想说而不是这样做,你可以在 angular 的 angular run/config 阶段设置你的变量。

代码

app.run(function($rootScope, myService){
 //set the variable inside $rootScope, this will available for any controller
 $rootScope.myVariable = 'setFromRunPhaseUsingRootScope';
 //you can use sharable service variable to set data, and use that inside your controller
 myService.myVariable = 'setFromRunPhaseUsingService'
});

希望这可以帮助你。

于 2015-02-13T20:37:52.833 回答