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/

相关文章

ANGULAR.JS:NG-SELECTANDNG-OPTIONSPS:其实看英文文档比看中...
AngularJS中使用Chart.js制折线图与饼图实例  Chart.js 是...
IE浏览器兼容性后续前言 继续尝试解决IE浏览器兼容性问题,...
Angular实现下拉菜单多选写这篇文章时,引用文章地址如下:h...
在AngularJS应用中集成科大讯飞语音输入功能前言 根据项目...
Angular数据更新不及时问题探讨前言 在修复控制角标正确变...