控制器上的ng模型值$scope为“未定义”


ng-model value $scope on controller is "undefined"

在我对Ionic Framework的研究中,我正在学习控制器,所以,我得到了这个简单的HTML代码(上面和下面的代码是由Ionic生成的代码,所以我没有触摸它)

 <div ng-controller="controller">    
  <ion-content>
    <img class="indexImg" src="img/saludoIndex.jpg">
    <br><br>
          <div class="item item-input-inset">    
              <label class="item-input-wrapper">
                  <i class="icon ion-at placeholder-icon"></i>
                  <input type="text" placeholder="Dirección de email" ng-model="mail">
              </label>
          </div>
          <div class="item item-input-inset">    
              <label  class="item-input-wrapper">
                  <i class="icon ion-locked placeholder-icon"></i>
                  <input type="text" placeholder="Contraseña" ng-model="word">
              </label><br>
          </div>
          <div class="col text-center">
              <br><h4><a>¿Olvidaste tu contraseña?</a></h4><br><br><br><br><br>
              <a class="button button-stable button-large" href="templates/Register.html">
              <b>Crear una cuenta gratuita</b></a>
          </div>

  </ion-content>
    <ion-footer-bar class="bar-positive tabs">
        <a class="tab-item">
            <h4 style="color:white;" ng-click="registrar()">INICIAR SESIÓN</h4>
        </a>
    </ion-footer-bar>
</div>

和我的JavaScript

(function (){
var app = angular.module('starter', ['ionic']);
var app2 = angular.module('nuevo', []);
app.controller('controller', function($scope, $http) {
$scope.registrar = function(){
    $http.post("http://127.0.0.1:8080/php/Conexion.php",{
        correo:$scope.mail, pass:$scope.word,    
    }).success(function(data){
   console.log("exito"); 
   console.log($scope.mail);
    });
}
});
app2.controller('registroUsuario', function($scope, $http){
$scope.nuevoUsuario= function(){
    $http.post("http://127.0.0.1:8080/php/RegistroUsuario.php",{
        tipo:$scope.tipo, cedula:$scope.cedula, nombres:$scope.nombre, apellidos:$scope.apellido, email:$scope.email, pass:$scope.contra, indicativo:$scope.indicativo, numero:$scope.numero,    
    }).success(function(data){
        console.log($scope.cedula);
        console.log($scope.nombre);
        console.log($scope.apellido);
        console.log($scope.email);
        console.log($scope.contra);
        console.log($scope.indicativo);
        console.log($scope.numero);
    });
}
});
app.run(function($ionicPlatform) {
  $ionicPlatform.ready(function() {
    if(window.cordova && window.cordova.plugins.Keyboard) {
      cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
      cordova.plugins.Keyboard.disableScroll(true);
    }
    if(window.StatusBar) {
      StatusBar.styleDefault();
    }
  });
 })
}())

正如你在上面看到的,这是一个基本的登录表单,我在我的第一个控制器注册器()中与我的$scope值一起使用ng-model="mail"和ng-model="word"时遇到了一些麻烦,该函数转到我的php文件,那里没有问题,但是,只是为了测试,我做了控制台打印以查看我的ng-models的值,它抛出了"exit "第一个消息和"undefined"为我的$scope的值。邮件值,与$scope相同。词的价值。

为什么会发生这种情况?我很困惑,因为我的其他控制器工作完美,我试图改变var

的值
app = angular.module('starter', ['ionic']);

var app = angular.module('starter', []);

,但这也给了我一个错误。我也试着用上面的值声明一个var app3,但仍然没有。

我希望你能帮我一下,谢谢你的时间。

我认为你必须在函数之前或函数内部初始化变量

app.controller('controller', function($scope, $http) {

$scope.mail = '';

$scope.word = '';
$scope.registrar = function(){
    $http.post("http://127.0.0.1:8080/php/Conexion.php",{
        correo:$scope.mail, pass:$scope.word,    
    }).success(function(data)
{
   console.log("exito"); 
   console.log($scope.mail);
    });
}
});

希望有帮助!