recherche

Maison  >  Questions et réponses  >  le corps du texte

angulaire.js - Une démo d'entrée de gamme très simple d'angularjs, mais une erreur a été signalée.

Je suis nouveau sur Angularjs et je lis un livre intitulé "Tutoriel faisant autorité sur Angularjs". Il y a une démo dans le deuxième chapitre, comme suit.

La version angulaire 1.2.29 est utilisée ici. Si elle est modifiée en 1.3.1, une erreur sera signalée.

Excusez-moi, comment est-ce arrivé ? Comment dois-je déboguer cette erreur ?

<!doctype html> 
<html ng-app> 
<head> 
    <meta charset="utf-8"> 
    <title>Simple App</title> 
    <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.2.29/angular.min.js"></script>
</head>
<body>
    <p ng-controller="MyController">
        <h1>Hello {{clock}}</h1>
    </p>
    
    <script type="text/javascript">
        function MyController($scope, $timeout) {
            $scope.clock = new Date();
            var updateClock = function() {
              $scope.clock = new Date();
            };
            setInterval(function() {
              $scope.$apply(updateClock);
            }, 1000);
            updateClock();
      };
    </script>
</body>
</html>
PHP中文网PHP中文网2814 Il y a quelques jours521

répondre à tous(2)je répondrai

  • 迷茫

    迷茫2017-05-15 16:58:52

    Après la version 1.3, les contrôleurs ne sont plus trouvés sur l'objet window $controller will no longer look for controllers on window.

    https://github.com/angular/angular.js/blob/master/CHANGELOG.md#breaking-changes-31

    <!DOCTYPE html>
    <html ng-app="app">
    <head>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js"></script>
      <meta charset="utf-8">
      <title>JS Bin</title>
    </head>
    <body>
     <p ng-controller="MyController">
            <h1>Hello {{clock}}</h1>
        </p>
        
        <script type="text/javascript">
         (function(){
            angular.module("app", []).controller("MyController", MyController);
          
             
            MyController.$inject = ['$scope', '$timeout'];
           
            function MyController($scope, $timeout) {
                $scope.clock = new Date();
                var updateClock = function() {
                  $scope.clock = new Date();
                };
                setInterval(function() {
                  $scope.$apply(updateClock);
                }, 1000);
                updateClock();
           }
         })();
        </script>
    </body>
    </html>

    Le Bin JS
    http://jsbin.com/vekixa/edit?html,console,output

    Si vous ne pouvez pas contourner le mur, veuillez changer le CDN à l'intérieur du mur

    répondre
    0
  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-05-15 16:58:52

    Il est recommandé que l'affiche fasse suite à la version 1.4 (la version est vraiment importante)

    <!doctype html> 
    <html ng-app> 
    <head> 
        <meta charset="utf-8"> 
        <title>Simple App</title> 
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.7/angular.min.js"></script>
    </head>
    <body>
        <p ng-controller="MyController">
            <h1>Hello {{clock}}</h1>
        </p>
        
        <script type="text/javascript">
            function MyController($scope, $timeout) {
                $scope.clock = new Date();
                var updateClock = function() {
                  $scope.clock = new Date();
                };
                setInterval(function() {
                  updateClock();
                }, 1000);
          };
        </script>
    </body>
    </html>
    

    Juste comme ça. . Bien sûr, vous pouvez aussi écrire

    <!doctype html> 
    <html ng-app> 
    <head> 
        <meta charset="utf-8"> 
        <title>Simple App</title> 
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.7/angular.min.js"></script>
    </head>
    <body>
        <p ng-controller="MyController">
            <h1>Hello {{updateClock()}}</h1>
        </p>
        
        <script type="text/javascript">
            function MyController($scope, $timeout) {
                $scope.updateClock = function() {
                 return new Date();
                };
                setInterval(function() {
                  updateClock();
                }, 1000);
          };
        </script>
    </body>
    </html>
    

    répondre
    0
  • Annulerrépondre