繁体   English   中英

控制器上的ng-model值$ 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值的第一个控制器registrar()中遇到ng-model =“ mail”和ng-model =“ word”的问题,该功能转到我的php文件,那里没有问题,但是,为了进行测试,我做了控制台打印以查看我的ng-models的值,并且它为我的$ scope.mail值的值抛出了“ exito” firts消息和“ undefined” $ scope.word值的值。

为什么会这样呢? 我很困惑,因为我的其他控制器工作正常,所以我试图更改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);
    });
}

});

希望有帮助!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM