gpt4 book ai didi

angularjs - Angular-Meteor - 如何在基于包的设计中包含 ng 模板?

转载 作者:行者123 更新时间:2023-12-02 23:38:26 24 4
gpt4 key购买 nike

我有一个 Angular-Meteor 应用程序正在运行。我想将 Angular 模板和关联的 Controller 打包到 Meteor 包中,并通过添加该包将这些模板注入(inject)到我的主应用程序中。

最好的方法是什么?

更新 2015-08-26 - 我弄清楚了如何添加模板,记录如下。但是如何让 Meteor 包将模板的 Angular Controller 注入(inject)到基础应用程序中呢?

一个关键的搭配是 Angular UI 路由器。

我有一个基础应用程序,其中包含名为 packageprefix:packagename 的包。在这个包中,我的代码位于包文件夹的根目录中:myPackagesPage.ng.html - Angular HTML 模板myPackagesPage.js - 关联的 Angular Controller

在我的主应用程序中,我尝试创建一条通往 Angular 模板的路径,如下所示:

angular.module('parentModule',[
'angular-meteor',
'ui.router',
'angularify.semantic.sidebar'
])

.config(['$urlRouterProvider', '$stateProvider', '$locationProvider',
function($urlRouterProvider, $stateProvider, $locationProvider){
console.log("app.js config!");
$locationProvider.html5Mode(true);

$stateProvider
.state('home', {
url: '/',
templateUrl: 'client/views/home/home.ng.html',
controller: 'HomeCtrl'
})

.state('myPackagedPage', {
url: '/myPackagedPage',
templateUrl: 'packageprefix_packagename/myPackagedPage.ng.html',
controller: 'MyPackagedPageCtrl'
})
;

$urlRouterProvider.otherwise('/');

}])

应用程序成功找到 myPackagesPage.ng.html 文件并呈现它。但是如何添加 Controller 呢?

我尝试将其添加到我的包中,但 Controller 功能没有被调用。

console.log("myPackagedPage.js loaded");
angular.module('parentModule')

.controller('MyPackagedPageCtrl', ['$scope',
function($scope){
console.log("MyPackagedPageCtrl");
}])
;

我收到错误:

Argument 'MyPackagedPageCtrl' is not a function, got undefined

最佳答案

我现在可以正常工作了。这是适合我的方法,将 Meteor 包中的 Angular Controller + 模板注入(inject)到包含的应用程序中。

在我的 package.js 中,我有这个

Package.onUse(function(api) {
api.versionsFrom('1.1.0.3');
api.use('angular:angular@1.4.4', 'client');
api.use("urigo:angular@0.9.3", 'client');
api.use("session@1.1.0", 'client');

//api.use('angularui:angular-ui-router@0.2.15', 'client');
api.addFiles('interests.js', 'client');
api.addFiles('interests.ng.html', 'client');

api.export("InterestsCtrl", "client")
});

请注意,您必须导出 Controller ,以便父应用程序可以访问它。

在我的名为 ramshackle:bigd-interests 的包中,我在根级别有这些文件:package.jsinterests.ng.htmlinterests.jsinterests.js 将 Angular Controller 、Anguilar UI 路由器路由注入(inject)模板,并将侧边栏链接注入(inject)父应用程序。它通过使用 Meteor Session 来实现这一点。我尝试过其他方法来做到这一点,但 session 是唯一有效的方法。请注意正确确定 session 变量名称的范围。

//add controllers
var controllers = Session.get("BIGD.controllers");
if (!controllers) controllers = {};

var interestsCtrlSpec = "'$scope', InterestsCtrl";

InterestsCtrl = function($scope){
console.log("InterestsCtrl running");
};
controllers.InterestsCtrl = interestsCtrlSpec;
Session.set("BIGD.controllers", controllers);

//add routes
var routes = Session.get("BIGD.routes");
if (!routes) routes = {};
routes.interests = {
url: '/interests',
templateUrl: 'ramshackle_bigd-interests_interests.ng.html',
controller: 'InterestsCtrl'
};
Session.set("BIGD.routes", routes);

//add sidebar links
//the key determines sorting order
var sidebar = Session.get("BIGD.sidebar");
if (!sidebar) sidebar = {};
sidebar["interests"] = {
url: '/interests',
templateUrl: 'ramshackle_bigd-interests_interests.ng.html',
controller: 'InterestsCtrl',
rank: 5
};
Session.set("BIGD.sidebar", sidebar);

var interestsItem = {label: 'Interests', link: '/interests', icon: "rocket"};

在我的父应用程序的 app.js 中,我从 session 中动态加载 Controller 和路由,如下所示:

angular.module('bigdam',[
'angular-meteor',
'ui.router',
'angularify.semantic.sidebar',
'nvd3',
'leaflet-directive',
'ui.router.history'
])

.config(['$urlRouterProvider', '$stateProvider', '$locationProvider',
function($urlRouterProvider, $stateProvider, $locationProvider){
//console.log("app.js config!");
$locationProvider.html5Mode(true);

//add a static state
$stateProvider
.state('home', {
url: '/',
templateUrl: 'client/views/home/home.ng.html',
controller: 'HomeCtrl'
});

//add the dynamic routes/states from other Meteor packages
for (var stateId in routes) {
var route = routes[stateId];
$stateProvider
.state(stateId, route);
}

$urlRouterProvider.otherwise('/');
}])
;

//Declare the controllers from plugins
for (var controllerId in controllers) {
var controllerSpec = controllers[controllerId];
var controllerSpecArray = eval("[" + controllerSpec + "]")
angular.module('bigdam').controller(controllerId, controllerSpecArray);
}

现在,当我创建一个新的 Meteor 包并遵循上述约定时,它的 Controller 、路由和侧边栏链接就会加载到主应用程序中。

关于angularjs - Angular-Meteor - 如何在基于包的设计中包含 ng 模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32209160/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com