angularjs - ng-view、父 Controller 、自定义指令的范围问题

标签 angularjs angularjs-directive angularjs-controller

我对自己的情况很困惑。我简单介绍一下我的情况。

HTML 结构。 (这只是结构,完整的 HTML 不止于此,但除了“pageController”之外没有任何其他 Controller )

<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"
                                    });
                            });

我现在没有设置任何 Controller 。我之前将每个 Controller 都作为“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中注入(inject)的html中,没有任何其他 Controller ,但它动态生成<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> 中看到的那样标签,我正在使用自定义指令图像加载器。在指令代码中,我希望“范围”与 pageController 的范围相同,只要 ng-view 中没有任何其他 Controller ,并且我没有在自定义指令中为范围提供任何选项。

但是我在控制台中打印了作用域对象,我可以作为父级的父级访问 pageController 作用域对象...为什么?????

scope.$parent.$parent.modalImgSrc = fileName;
scope.$parent.$parent.isModalOpen = true; 

scope.$parent.$parent.$digest();

感谢您阅读我的长篇文章...请帮助...我为此花了 2 天时间..

你可以在我的个人网站上看到完整的代码。我是 angularJS 的菜鸟。我正在将网站的 JQuery 版本转换为纯 angularJS 版本以学习 AngularJS。正在进行中。

AngularJS 版本..(正在转换) http://bear-mj.com/MJKim

JQuery 版本..(所有工作) http://bear-mj.com/MJKimJQuery/

最佳答案

您创建了 3 级范围。请记住,ng-repeatng-view 都会创建一个新范围。在您应用的这个区域 - 在指令内:

  1. scopeng-repeat 作用域
  2. scope.$parentng-view 作用域
  3. scope.$parent.$parentpageController 作用域

关于angularjs - ng-view、父 Controller 、自定义指令的范围问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38810271/

相关文章:

javascript - AngularJS 导航

javascript - ng-repeat 上的嵌入

angularjs - 在 angularjs 指令中将优先级设置为高于 '0' 可防止包含

javascript - 在另一个函数中调用相同范围内的函数 -AngularJS - 错误

javascript - Angular : updating view with value passed from directive to controller

javascript - 错误: [$injector:unpr] Unknown provider: $scope in angular Js when routing

angularjs - 使用抽象状态的目的是什么?

javascript - 为什么 Cesium 查看器在我添加时不显示模型?

Javascript lodash 展平分层对象

javascript - 如何在 Angular Directive(指令)中使用回调作为监视表达式?