Tengo este módulo de rutas:
var mainModule = angular.module('lpConnect', []).
config(['$routeProvider', function ($routeProvider) {
$routeProvider.
when('/home', {template:'views/home.html', controller:HomeCtrl}).
when('/admin', {template:'views/admin.html', controller:AdminCtrl}).
otherwise({redirectTo:'/connect'});
}]);
Inicio HTML:
<div ng-include src="views.partial1"></div>
partial1 HTML:
<form ng-submit="addLine()">
<input type="text" ng-model="lineText" size="30" placeholder="Type your message here">
</form>
HomeCtrl:
function HomeCtrl($scope, $location, $window, $http, Common) {
...
$scope.views = {
partial1:"views/partial1.html"
};
$scope.addLine = function () {
$scope.chat.addLine($scope.lineText);
$scope.lines.push({text:$scope.lineText});
$scope.lineText = "";
};
...
}
En la addLinefunción $scope.lineTextes undefined, esto se puede resolver agregando ng-controller="HomeCtrl"a partial1.html, sin embargo, hace que se llame dos veces al controlador. ¿Que me estoy perdiendo aqui?
fuente


$parent.$parent...para que funcione. Dicho de otra manera, el uso$parenthace suposiciones sobre la estructura DOM.En lugar de usar
thiscomo sugiere la respuesta aceptada, use$parenten su lugar. Entonces en tupartial1.htmltendrás:Si desea obtener más información sobre el alcance
ng-includeu otras directivas, consulte esto: https://github.com/angular/angular.js/wiki/Understanding-Scopes#ng-includefuente
$scope.$parentlugar de$parentestá indefinido según Angular.$scope.$parentque funciona para mí en angular 1.3.20He descubierto cómo solucionar este problema sin mezclar datos primarios y secundarios. Establezca a
ng-ifen elng-includeelemento y configúrelo en una variable de ámbito. Por ejemplo :En su controlador, cuando haya configurado todos los datos que necesita en su sub ámbito, luego configure show en
true. Enng-includeeste momento, copiará el conjunto de datos en su ámbito y lo establecerá en su sub ámbito.La regla general es reducir los datos del alcance más profundamente, de lo contrario, tiene esta situación.
Max
fuente