微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

angularjs – Angular – 无法在ng-switch-when内观看

我需要$观察范围的变量,但它永远不会被调用.
我发现它与ng-switch-when有关.

例如:
http://jsfiddle.net/gGKGX/

angular.module("GuyModule",[]).controller("GuyController",function($scope) {

    $scope.something = "foo";

      $scope.guy="This is guy";

    $scope.$watch('guy',function(){ console.log("guy changed!"); }  );

} );


<div  ng-controller="GuyController" ng-app="GuyModule">
    <div ng-switch="something">
        <div ng-switch-when="foo">
            <input ng-model="guy"/>
        </div>
        <div ng-switch-when="bar">
            <button ng-click="something='bar'">Click me!</button>
        </div>
    </div>
</div>

我希望“家伙改变了!”要打印但不是,当我删除“ng-switch-when”时它可以工作.
我该如何解决这个问题?

顺便说一句 – 同样的事情发生在ui-if(来自angularui项目).

解决方法

家伙是在开关和控制器的范围内.

正如您在图片中看到的那样,两个范围都存在.在编辑它时,您正在ng-switch的范围内进行编辑,而不是正在编辑您正在观看的那个

一个例子是在交换机外显示人:http://jsfiddle.net/TheSharpieOne/gGKGX/1/

解决此问题:将$parent添加到交换机中的人($parent.guy):http://jsfiddle.net/TheSharpieOne/gGKGX/2/

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐