Naprawiłem kilka rzeczy.
http://plnkr.co/edit/5Zaln7QT2gETVcGiMdoW?p=preview
JS
var myMod = angular.module("myApp",[]).controller("MainController", function($scope){
$scope.myModel = {selectedId:null};
}).controller("DetailController",function($scope){
$scope.items = [1,2,3,4];
$scope.watchHitCount = 0;
$scope.$watch('myModel.selectedId', function(newVal, oldVal){
console.log(newVal + " " + oldVal);
$scope.watchHitCount++;
},true);
});
index.html
<body ng-app="myApp">
<div ng-controller="MainController">
<ng-include src="'detail.html'" ng-controller="DetailController"></ng-include>
</div>
</body>
detail.html
<pre>watch hit: {{watchHitCount}}</pre>
<pre>selected value: {{myModel.selectedId}}</pre>
<select ng-model="myModel.selectedId" ui-select2="">
<option></option>
<option ng-repeat="item in items" value="{{item}}">{{item}}</option>
</select>
został skarżą się na nie findi ng kontrolera, więc ustawiłem go tak, jak normalnie z nazwaną ng-app i modułem zadeklarowanym, że ma zdefiniowane kontrolery.
Dodałem również obiekt do przechowywania wartości w modelu. Złą praktyką jest używanie obiektu $ scope jako modelu, zamiast tego twój zakres powinien odnosić się do obiektu, który jest twoim modelem.
miałem $ nie oglądam strzelania ale okazuje się, że miałem ng-jeśli tworzyłem nowy zakres, więc musiałem umieścić ng-model = "$ parent.myModal", ponieważ faktycznie obserwowałem rodziców myModal .. –