ng-view、父控制器、自定义指令的范围问题
scope issue with ng-view, parent controller, custom directive
我对自己的情况很困惑。我简单介绍一下我的情况。
HTML结构。 (这只是结构,完整的 HTML 不止于此,但除了 "pageController" 之外没有任何其他控制器)
<body ng-app="app">
<div id="wrapper" ng-controller="pageController">
<div id="menu">
<a>.........</a>
</div>
<div id="mainView">
<ng-view></ng-view>
</div>
</div>
</body>
当然,我正确设置了路由器。
var app = angular.module("app", ["ngRoute"])
.config(function($routeProvider){
$routeProvider
.when("/about", {
templateUrl: "about.html"
})
.when("/summary", {
templateUrl: "summary.html"
})
.when("/company", {
templateUrl: "company.html"
})
.when("/remote", {
templateUrl: "remote.html"
})
.when("/personal", {
templateUrl: "personal.html"
})
.when("/academic", {
templateUrl: "academic.html"
})
.otherwise({
redirectTo : "/about"
});
});
我现在没有设置任何控制器。我之前把每个控制器都放在 "pageController" 但我现在删除了,因为我认为只要 pageController 在父元素中,pageController 就会自动继承。
我做了自定义指令。
app.directive('imageLoader', function(){
return{
restrict:'A',
link:function(scope, elem, attrs){
elem.bind('click', function(){
var fileName = "img/portfolioImages/" + attrs.ori;
scope.$parent.$parent.modalImgSrc = fileName;
scope.$parent.$parent.isModalOpen = true;
scope.$parent.$parent.$digest();
});
}
};
});
在 ng-view 中注入 html,没有任何其他控制器,但它会动态生成 <img>
标签,如下所示
<div class="project-image-div">
<img image-loader ng-repeat="aImgSrc in remoteImageFiles[0]"
data-ori='{{aImgSrc}}' class='project-img-s'
ng-src='img/portfolioImages/{{aImgSrc.substring(0,aImgSrc.lastIndexOf(".")) + "_s" + aImgSrc.substr(aImgSrc.lastIndexOf("."), 4)}}'>
</div>
remoteImageFiles[0] 是保存在 pageController 范围内的 json 对象。而这些动态添加的img标签完全没问题
问题
正如您在 <img>
标记中看到的,我正在使用自定义指令图像加载器。在指令代码中,我希望 "scope" 与 pageController 的范围相同,只要 ng-view 中没有任何其他控制器,并且我没有在自定义指令中为范围提供任何选项。
但是我在控制台中打印了范围对象,我可以作为父对象的父对象访问 pageController 范围对象... 为什么?????
scope.$parent.$parent.modalImgSrc = fileName;
scope.$parent.$parent.isModalOpen = true;
scope.$parent.$parent.$digest();
感谢您阅读我的长文post...请帮忙...我为此花了 2 天时间..
你可以在我的个人网站上看到完整的代码。我是 angularJS 的菜鸟。我正在将站点的 JQuery 版本转换为纯 angularJS 版本以学习 AngularJS.. 正在进行中。
AngularJS 版本..(正在转换)
http://bear-mj.com/MJKim
JQuery 版本..(所有工作)
http://bear-mj.com/MJKimJQuery/
您创建了 3 级范围。请记住,ng-repeat
和 ng-view
都会创建一个新范围。在您应用的这个区域 - 在指令内:
scope
是 ng-repeat
范围
scope.$parent
是 ng-view
范围
scope.$parent.$parent
是 pageController
范围
我对自己的情况很困惑。我简单介绍一下我的情况。
HTML结构。 (这只是结构,完整的 HTML 不止于此,但除了 "pageController" 之外没有任何其他控制器)
<body ng-app="app">
<div id="wrapper" ng-controller="pageController">
<div id="menu">
<a>.........</a>
</div>
<div id="mainView">
<ng-view></ng-view>
</div>
</div>
</body>
当然,我正确设置了路由器。
var app = angular.module("app", ["ngRoute"])
.config(function($routeProvider){
$routeProvider
.when("/about", {
templateUrl: "about.html"
})
.when("/summary", {
templateUrl: "summary.html"
})
.when("/company", {
templateUrl: "company.html"
})
.when("/remote", {
templateUrl: "remote.html"
})
.when("/personal", {
templateUrl: "personal.html"
})
.when("/academic", {
templateUrl: "academic.html"
})
.otherwise({
redirectTo : "/about"
});
});
我现在没有设置任何控制器。我之前把每个控制器都放在 "pageController" 但我现在删除了,因为我认为只要 pageController 在父元素中,pageController 就会自动继承。
我做了自定义指令。
app.directive('imageLoader', function(){
return{
restrict:'A',
link:function(scope, elem, attrs){
elem.bind('click', function(){
var fileName = "img/portfolioImages/" + attrs.ori;
scope.$parent.$parent.modalImgSrc = fileName;
scope.$parent.$parent.isModalOpen = true;
scope.$parent.$parent.$digest();
});
}
};
});
在 ng-view 中注入 html,没有任何其他控制器,但它会动态生成 <img>
标签,如下所示
<div class="project-image-div">
<img image-loader ng-repeat="aImgSrc in remoteImageFiles[0]"
data-ori='{{aImgSrc}}' class='project-img-s'
ng-src='img/portfolioImages/{{aImgSrc.substring(0,aImgSrc.lastIndexOf(".")) + "_s" + aImgSrc.substr(aImgSrc.lastIndexOf("."), 4)}}'>
</div>
remoteImageFiles[0] 是保存在 pageController 范围内的 json 对象。而这些动态添加的img标签完全没问题
问题
正如您在 <img>
标记中看到的,我正在使用自定义指令图像加载器。在指令代码中,我希望 "scope" 与 pageController 的范围相同,只要 ng-view 中没有任何其他控制器,并且我没有在自定义指令中为范围提供任何选项。
但是我在控制台中打印了范围对象,我可以作为父对象的父对象访问 pageController 范围对象... 为什么?????
scope.$parent.$parent.modalImgSrc = fileName;
scope.$parent.$parent.isModalOpen = true;
scope.$parent.$parent.$digest();
感谢您阅读我的长文post...请帮忙...我为此花了 2 天时间..
你可以在我的个人网站上看到完整的代码。我是 angularJS 的菜鸟。我正在将站点的 JQuery 版本转换为纯 angularJS 版本以学习 AngularJS.. 正在进行中。
AngularJS 版本..(正在转换) http://bear-mj.com/MJKim
JQuery 版本..(所有工作) http://bear-mj.com/MJKimJQuery/
您创建了 3 级范围。请记住,ng-repeat
和 ng-view
都会创建一个新范围。在您应用的这个区域 - 在指令内:
scope
是ng-repeat
范围scope.$parent
是ng-view
范围scope.$parent.$parent
是pageController
范围