gpt4 book ai didi

javascript - angular,访问 ng-view 包装 div 之外的范围

转载 作者:行者123 更新时间:2023-11-30 12:32:28 25 4
gpt4 key购买 nike

我正在尝试在我的应用程序上设置自定义主题,所以我正在做的是让用户选择某些主题,它会从整体上改变应用程序的主题。我有一个服务,它发送一段 json 并监听它在每个 View 的 Controller 内部的变化。现在这在 View 本身中工作正常 - 这里有一些工作代码片段供引用。

我的工厂控制主题 -

angular.module('demoApp')
.factory('templatingFactory', function () {

var meaningOfLife =
{
'h1': '#ea6060',
'bg': '#ffffff'
};

return {
setTheme: function(theme) {
meaningOfLife = theme;

},
getTheme: function() {
return meaningOfLife;
}
};

});

我的示例 Controller 之一显示和更改主题(并监听更改)

$scope.themeStore = templatingFactory.getTheme();
console.log($scope.themeStore);

//send new themes
$scope.themeOne = function () {
var newT1 = { 'h1': '#8A6516',
'bg': '#000000'};
templatingFactory.setTheme(newT1);

};

$scope.themeTwo = function () {
var newT2 = { 'h1': '#ffffff',
'bg': '#ea6060'};
templatingFactory.setTheme(newT2);


};

$scope.themeThree = function () {
var newT3 = { 'h1': '#ea6060',
'bg': '#ffffff'};
templatingFactory.setTheme(newT3);


};
//listen for new themes
$scope.watchThemes = templatingFactory.getTheme();
$scope.$watch(templatingFactory.getTheme, function (newTheme) {

$scope.themeStore = newTheme;

});

然后在模板/ View 本身上我做了这样的事情-

<h3 ng-style="{ 'color' : themeStore.h1 }">Title</h3>

所以我的问题是这在 View 中工作正常。然而,ng-view 标签位于主体内部,外部是主体容器,以及我希望能够与该主题对象 Hook 的页眉和页脚菜单。所以我的问题是,有没有办法在 ng-view 之外使用该范围?我不认为这是可能的,但我不确定我还能如何访问并在页眉页脚和正文上放置 ng-style 以使用我正在使用的这种方法更改其上的一些 css。

所以为了一个简单的引用,它看起来像这样 -

<body ng-app="myApp">
<div class="container">

<div class="header" ng-style="{ 'background-color' : themeStore.bg }">

<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<i class="fa fa-bars"></i>
</button>
<div class="headerLogo"></div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav navbar-right">

</ul>
</div>
</div>

<div ng-view class="velocity-opposites-transition-slideUpIn" data-velocity-opts="{ duration: 500 }" ng-style="{ 'background-color' : themeStore.bg }"> </div>

<div class="footer">
<p></p>
</div>
</div>

</body>

如您所见 - 我正在尝试连接到页眉以更改背景颜色,但这种方法无法正常工作。不过我注意到,如果我将它放在 ng-view div 本身上,它就可以正常工作。

我将非常感谢任何意见,因为我已经坚持了一段时间。感谢您花时间阅读!

最佳答案

ng-view 之外的 DOM 元素必须有自己的 Controller ,templatingFactory 作为依赖注入(inject)。

首先我会像这样修改 html:

<div class="header" ng-controller="headerController" ng-style="{ 'background-color' : themeStore.bg }">

然后将 headerController 添加到您的模块中:

angular.module('demoApp').controller('headerController', function($scope, templatingFactory){
$scope.themeStore = templatingFactory.getTheme();

$scope.$watch(templatingFactory.getTheme, function (newTheme) {
$scope.themeStore = newTheme;
});

});

一个更可重用的解决方案是创建一个指令,将此 Controller 功能添加到它所应用的任何 DOM 元素,但上面的方法更直接一些。

关于javascript - angular,访问 ng-view 包装 div 之外的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27234655/

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