簡體   English   中英

角js ng單擊不起作用

[英]Angular js ng-click not working

我正在嘗試使用JavaScript添加表單驗證。 當我添加

 document.getElementById("one").setAttribute("ng-click", "insertData()"); 

validateForm功能,當我按下按鈕后不起作用。

當我將該行移出validateForm函數時,它可以工作,但不執行表單驗證。

這是我的代碼:

<!DOCTYPE html>
<html lang="en">
<head>

<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.4/angular.min.js"></script>

</head>
<body>

<div class="container">
   <div ng-app="myapp" ng-controller = "controller">
        <div class="row">
            <div id="divID"> </div>
                <div class="col-sm-12 col-md-10  col-md-offset-1 ">
                    <div class="form-group">
                        <div class="input-group">
                            <span class="input-group-addon"><i class="glyphicon glyphicon-user"></i></span> 
                            <input class="form-control" id = "k" placeholder="Name" ng-model = "username" name="user_name" type="text" autofocus>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="input-group">
                            <span class="input-group-addon">
                                <i class="glyphicon glyphicon-user"></i></span>
                            <input class="form-control" placeholder="NIC" ng-model = "nic" name="NIC" type="text" value="">
                        </div>
                    </div>

             <div class="form-group">
                        <div class="input-group">
                            <span class="input-group-addon"> @</span>
                            <input class="form-control" placeholder="Email" ng-model = "Email" name="email" type="email" value="">
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="input-group">
                            <span class="input-group-addon">
                                <i class="glyphicon glyphicon-lock"></i></span>
                            <input class="form-control" placeholder="Password" ng-model = "password" name="Password" type="password" value="">
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="input-group">
                            <span class="input-group-addon">
                                <i class="glyphicon glyphicon-lock"></i></span>
                            <input class="form-control" placeholder="Confierm Password" ng-model = "Conf_password" name="Conf_password" type="password" value="">
                        </div>
                    </div>

                    <div class="form-group">
                        <input type="submit" id = 'one' onclick="validateForm()"  class="btn btn-lg btn-primary btn-block" value="Sign Up">
                    </div>
                </div>
            </div>
       </div>
   </div>
  </body>
</html>
  <Script>
     function validateForm() 
       {
       var x = document.getElementById("k").value;
       if (x == "") 
         {
         document.getElementById("k").setAttribute("placeholder", "Insert Name");
         }
         else
         {
           //document.getElementById("one").removeAttribute("onclick");
           document.getElementById("one").setAttribute("ng-click", "insertData()");
          } 
       }
      // when add this part here code working fine ---- document.getElementById("one").setAttribute("ng-click", "insertData()");        

     var app = angular.module("myapp", []);
     app.controller("controller",function($scope,$http){
     $scope.insertData = function()
        {
         $http.post(
        "Signup.php",
        {'username':$scope.username,'nic':$scope.nic,'email':$scope.Email,'password':$scope.password,'Conf_password':$scope.Conf_password }

    ).then(function(data){

     var result = angular.toJson(data.data);
     var myEl = angular.element( document.querySelector( '#divID' ) );
     if(result.replace(/^"|"$/g, '') == 1)
       {
       myEl.replaceWith("<div class='alert alert-success alert-dismissable fade in'><a href='#' class='close' data-dismiss='alert' aria-label='close'>&times;</a><strong>Success!</strong>You have sucessfully registerd. Please login</div>"); 
       }
     else
        {
         myEl.replaceWith(result.replace(/^"|"$/g, '')); 
         }
      $scope.username = null;
    });
  }
});

</script>

好的,您要嘗試的不是angularjs的工作方式;而是 我建議您閱讀angularjs表單文檔 ,尤其是“ 綁定到表單和控制狀態”一章。 您的代碼似乎在jquery和angularjs之間發生沖突,我建議您重新閱讀angularjs phonecat教程,或者甚至更好的是,嘗試使用新版本的angularjs

您需要告訴Angular您已經添加了一個屬性,否則它不起作用。 將屬性添加到模板文件時,Angular知道,但是通過setAttribute()添加屬性時,Angular不知道。


在您的控制器中,添加以下兩個依賴項:

app.controller("controller", function($compile, $document, $scope, $http) {
    // 
});

現在,在將屬性添加到元素之后,您需要重新編譯它:

$document.getElementById("one").setAttribute("ng-click", "insertData()"); 

// Try this:
$compile($document.getElementById("one"));

// If it doesn't work, or gives an error, try this:
$compile($document.getElementById("one"))($scope);

注意:我使用$ document,而不是document

$ compile的文檔


注意:我無法真正測試這是否適用於您的代碼,但至少應為您指明正確的方向。 您的問題是Angular不知道您添加了該屬性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM