我面临的问题与Conditionally-rendering css in html head 中描述的问题相似(但不完全相同,请多多包涵)
我也在“懒惰地”加载样式表,从我在控制器一开始初始化的范围变量中获取文件名:
<link rel="stylesheet" data-ng-href="css/{{ filename }}.css" />
正如我正在使用ng-href
的(此处以它的data-
形式),我确实在避免不需要的请求,例如:
http://localhost/css/%7B%7B%20filename%7D%7D.css
但这一切仍然太快了,我几乎每次都得到这个:
http://localhost/css/.css
这似乎意味着请求在 Angular 删除自己的标记和用正确的值替换它的那一刻之间触发(稍后它会这样做,然后我的样式表正确加载)。我想这根本不可能……!?
我想我可能为filename
范围变量提供值太晚了,但正如我所说,这是在我的控制器中完成的第一件事:
angular.module('myControllers', [])
.controller('TestCtrl', ['$scope', function($scope) {
$scope.filename = 'test';
// some more code...
}]);
我正在使用 Angular 1.1.5 ;我能做些什么吗?这没什么大不了的,但如果我能解决它仍然会更好。
编辑:这里是完整的代码,根据要求。我不会包含页面模板,因为它们与问题无关。
索引.html:
<!DOCTYPE html>
<html lang="en" data-ng-app="myapp">
<head>
<meta charset="utf-8" />
<title>My App</title>
<link rel="stylesheet" data-ng-href="/assets/css/{{ filename }}.css" />
</head>
<body>
<div id="app" class="app" style="display: none;" data-ng-view></div>
<script src="/assets/js/lib/angular/angular.min.js"></script>
<script src="/assets/js/app/app.js"></script>
<script src="/assets/js/app/controllers.js"></script>
</body>
</html>
应用程序.js:
var app = angular.module('myapp', ['myControllers'])
.config(['$locationProvider', '$routeProvider', function($locationProvider, $routeProvider) {
$locationProvider.hashPrefix('!');
$routeProvider
.when('/', {
templateUrl: 'path/to/my/template.html',
controller: 'TestCtrl'
})
.otherwise({ redirectTo: '/' });
}]);
app.run();
控制器.js:
angular.module('myControllers', [])
.controller('TestCtrl', ['$scope', '$rootScope', function($scope, $rootScope) {
$rootScope.filename = 'stylesheet';
}]);
(是的,我尝试使用一个空控制器,就像这个一样,同样的问题。)