3

我想了解如何从控制器加载视图?

示例,假设:

myFile.html
<p>{{foo}}</p>

.controller("myCtrl", function(){
    $scope.html = loadFileHere("My foo", "myFile.html");
    console.log($scope.html);
});

I'd expect the output:
<p>My foo</p>

这可能吗?

谢谢!

4

1 回答 1

2

我猜你在谈论加载部分?您不会真正使用控制器加载视图,尽管您可能可以......我会使用您的路线来加载视图。您的控制器会将您的范围数据返回到您的局部视图,然后您将其加载到 ng-view div 或其他任何内容中。所以例如...

在你的 app.js (或任何你称之为的)中假设你的 myFile.html 是在同一个目录中:

angular.
    module('app', []).
    config(['$routeProvider', function($routeProvider) {
        $routeProvider.
        when('/myFile', { templateUrl: 'myFile.html', controller: MyCtrl }).
        otherwise({ redirectTo: '/' });
}]);

然后可能在 controllers.js 文件中:

function MyCtrl($scope) {
    $scope.foo = "My foo";
}

然后在您的 myFile.html 部分中:

<p>{{foo}}</p>

然后您的 index.html 文件可能类似于:

<!doctype html>
<html ng-app="app">
<head>
    <script src="js/angular.min.js"></script>
    <script src="js/app.js"></script>
    <script src="js/controllers.js"></script>
</head>
<body>
<div ng-controller="MyCtrl">
    <div class="container">

        <div ng-view></div>

    </div> <!-- /container -->
</div>
</body>
</html>
于 2013-09-24T15:59:47.900 回答