我正在使用 Ionic 来启动一个新的 Phonegap 应用程序。它依赖于 Angular。
所以这里是视图:
<ion-view title="'Login'" left-buttons="leftButtons">
<ion-content has-header="true">
<input type="text" ng-model="new_name" placeholder="Name">
{{new_name}}
<input type="text" ng-model="new_text" placeholder="Message..." ng-keydown="addMessage($event)">
</ion-content>
</ion-view>
控制器:
.controller('LoginCtrl', function($scope) {
$scope.new_name = "ininame";
$scope.addMessage = function(e) {
console.log($scope);
if (e.keyCode != 13) return;
console.log({name: $scope.new_name, text: $scope.new_text});
};
})
和配置:
.state('eventmenu.login', {
url: "/login",
views: {
'menuContent' :{
templateUrl: "templates/login.html",
controller: "LoginCtrl"
}
}
})
所以 {{new_name}} 在更改上述输入时会更新,但控制器中 $scope.new_name 的值仍然是“ininame”并且永远不会改变。触发该功能时,console.log 显示。
请注意,如果我使用 ng-controller = "LoginCtrl" 添加一个 div,如下所示:
<ion-view title="'Login to Wallit'" left-buttons="leftButtons">
<ion-content has-header="true">
<div ng-controller="LoginCtrl">
<div ng-repeat="msg in messages"><em>{{msg.name}}</em>: {{msg.text}}</div>
<input type="text" ng-model="new_name" placeholder="Name">
{{new_name}}
<input type="text" ng-model="new_text" placeholder="Message..." ng-keydown="addMessage($event)">
</div>
</ion-content>
</ion-view>
它完美地工作。模块配置中控制器的绑定应该与常规控制器的工作方式相同!
困惑...提前感谢您的帮助!