首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角度,队列ng-init

角度,队列ng-init
EN

Stack Overflow用户
提问于 2016-01-04 05:45:00
回答 1查看 394关注 0票数 2

是否有可能排队ng-init?通常,在第一个初始化中,我希望将JSON文件添加到prototype vars (数组)中,在另一个初始化中,根据参数的不同,我想跳过getJsonData()或将其他JSON文件添加到原型中。

代码语言:javascript
复制
function init(param) {
        console.log("startInit");

        // big JSON file
        var promise =  getJSON(param);  
        return promise.then( function() {
            //some func
            console.log("finish");
            return true;
        });
    };

    function getJSON(param) {
        var deferred = $q.defer();
        console.log("startInitDataInner");
            someService.getJsonData(param).then(function(data) {
                // some code
                console.log("endInitDataInner");
                deferred.resolve();

            }, function(error) {
                deferred.reject();
            });

        return deferred.promise; 

    }; 

在视图ng-init中

代码语言:javascript
复制
ng-init="init(param)"
ng-init="init(param)"
// ...

和日志:

代码语言:javascript
复制
startInit
startInitDataInner
startInit
startInitDataInner
endInitDataInner
finish
endInitDataInner
finish
//..

编辑:

一般来说,我想在jQuery中创建类似插件的东西。我有这样的代码:

代码语言:javascript
复制
<div ng-controller="parentController as parent">
   <div ng-controller="childController as child" ng-init="child.init(parent.data)"></div>
</div>

<div ng-controller="parentController as parent">
   <div ng-controller="childController as child" ng-init="child.init(parent.data2)"></div>
</div>

和可由用户配置的部件:

代码语言:javascript
复制
 angular.module('myApp').controller('parentController', ['$scope', function($scope) {
 this.data = {
    config: {
       lang: "en",
       title: "title"
       }
 };
 this.data2 = {
    config: {
       lang: "pl",
       title: "title2"
    }
 };         
 }]);

ng-init更新接口:

代码语言:javascript
复制
angular.extend(this, parent.data);

你知道我该怎么做吗?

EN

回答 1

Stack Overflow用户

发布于 2016-01-04 06:26:55

如果你使用的是angular,你可以使用控制器。控制器itslfmin的一般含义是什么?对,它是一个构造函数。这里的主词是函数。一般的功能是什么?运行里面的代码。

所以,只要把你的初始逻辑放在控制器代码的地方(但不把它包装成一个单独的函数),它就会及时运行,你的控制器将被角度解析器解析。

代码语言:javascript
复制
var controller = function () {
    // vars, costs, etc.
    console.log("startInit");

    // big JSON file
    var promise =  getJSON(param);  
    return promise.then( function() {
        //some func
        console.log("finish");
        return true;
    });

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

https://stackoverflow.com/questions/34581958

复制
相关文章

相似问题

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