ホームページ >ウェブフロントエンド >jsチュートリアル >AngularJs学習コントローラー、データバインディング、スコープ詳細説明

AngularJs学習コントローラー、データバインディング、スコープ詳細説明

零下一度
零下一度オリジナル
2017-07-23 18:05:211434ブラウズ

1. コントローラー:

概念: angularJS では、コントローラーはビューのスコープに追加機能を追加し、スコープの初期状態を設定し、カスタム動作を追加するために使用される関数です。

コントローラーの宣言: app.controller('controllerName',function($scope){...})

//    控制器定义//    第一参数: 控制器名称, 第二个参数: 匿名函数, 传入作用域,并在作用域上添加额外功能app.controller('myCtrl', function($scope) {
        $scope.expression = "hello expression";
        $scope.ngbind = "hello ng-bind";
        $scope.htmlbind = "d12c29ee83e5b622484f1e9842eecbbdhello,htmlbinde6e38b3c62e8df885fe2e3986461aa63";
        $scope.subCtrl = "hello subCtrl";

    });

コントローラーの使用法: 必要な場所 (html のどこかのタグ) に ng- を追加しますコントローラ。

<body ng-app="myapp" ng-controller="myCtrl">

上記から、コントロールの定義と使用法は比較的簡単ですが、多くの人はコントローラーの役割とコントローラーにどのようなコードを記述する必要があるのか​​理解できないでしょう。全体 コードはすべてコントローラーにプッシュされます。個人的には、コントローラーは、一部のデータ バインディング、イベント バインディング、その他の単純なロジック、特定のサーバー アクセス、またはデータ読み取りを処理するだけであると感じます。サービスに実装されるはずです。サービスについては次回詳しく説明します。

コントロールを使用する際の注意点を簡単に整理しましたので、ご参考までに:

1) コントローラーと$scope関連の操作を可能な限り簡略化します。
2) コントローラーを再利用しないでください。コントローラーは通常、ビューのごく一部のみを担当します。
3) コントローラーで DOM を操作しないでください。これはコントローラーの責任ではありません。
4) コントローラーでデータのフィルタリングやデータ操作を行わないように注意してください。
5) 一般的に、コントローラー間の対話はイベントを通じて行われます

2. スコープ ($scope)

スコープは上記のコントローラーにも記載されており、コントローラーは主に操作を実行します。 $scope に関連して、AngularJs におけるスコープの役割とそのライフサイクルについて簡単に説明します:

3。 :

AngularJs データ バインディングにもいくつかのバインディングがあります。おそらく、誰もがそれらを使用したことのないものがあるかもしれません。 ️ {{abc}} 関数: {{func()}} 式: {{a+b }}
Angular が式バインディングに遭遇する限り、このメソッドが最も一般的です。範囲Angular の場合、Html で認識される式または変数に自動的に解析されます。

2) 命令メソッド (ng-bind):

このバインド方法は、要素に ng-bind 命令を追加し、Angular がその命令を解析してバインドを実行します。 O 3) NG-MODEL:

このメソッドは主にフォームのフォーム送信に使用され、双方向データ バインディング、およびページ コンテンツとモデル間の双方向データを実現します。 ng-bind-htmlメソッドのみですが、バインディングはシリアル化されたJSファイルを参照する必要があります。

 bea4b67a9fe0f78efa78bb17563afef42cacc6d41bbb37262a98f745aa00fbf0

5) ng-bind-template:

このメソッドは一度に複数の変数と式をバインドできます。

使用シナリオ:

ホームページは ng-bind を使用し、テンプレート内のページは括弧 {{}} を使用できます。フォームは ng-model を使用します。

{{}} 構文の欠陥: ユーザーの定期的な更新で{} が表示されることもあり、ネットワークが良好でない場合には

が表示されることもあります。 以下のコードは、上記 5 つのメソッドの全体的なコードです。

以上がAngularJs学習コントローラー、データバインディング、スコープ詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。