1. 程式人生 > >angularJS初學篇-1添加隨筆

angularJS初學篇-1添加隨筆

不可見 src fin count -a one inpu 引導 del

1.頭部引入angularJS文件

<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>

2.angularjs指令

ng-app

  --指定了一個Angularjs的應用程序

  ng-app 指令定義了 AngularJS 應用程序的 根元素

    ng-app 指令在網頁加載完畢時會自動引導(自動初始化)應用程序。

    稍後您將學習到 ng-app 如何通過一個值(比如 ng-app="myModule")連接到代碼模塊。

  ng-model

    --把輸入域的值(元素值)綁定到應用程序。

ng-model 指令也可以:

    • 為應用程序數據提供類型驗證(number、email、required)。
    • 為應用程序數據提供狀態(invalid、dirty、touched、error)。
    • 為 HTML 元素提供 CSS 類。
    • 綁定 HTML 元素到 HTML 表單。

  ng-bind

    --把應用程序數據綁定到html視圖。

  ng-init

     --初始化應用程序變量

    --通常情況下,不使用 ng-init。您將使用一個控制器或模塊來代替它。

    --稍後您將學習更多有關控制器和模塊的知識。

<div ng-app="" ng-init="firstng=‘hang‘"> -----指定了一個Angularjs的應用程序

  <input type="text" ng-model="firstng"/> --把輸入域的值(元素值)綁定到應用程序。

  {{ firstng }} ---獲取綁定到應用程序的值

</div>

ng-repeat --有點類似foreach功能

    

<div ng-app="" ng-init="names=[
  {name:Jani,country:
Norway},   {name:Hege,country:Sweden},   {name:Kai,country:Denmark}]">   <p>循環對象:</p>   <ul>    <li ng-repeat="x in names">    {{ x.name + , + x.country }}    </li>   </ul> </div>

技術分享

3.angularjs表達式

  寫在HTML body裏面

  1.表達式寫在雙大括號內: {{ 表達式 }}

    例如:<div ng-app="" ag-init="obj">

    其中ag-init應用程序中的初始變量初始值可為json對象,數組,任意值。obj=[‘a‘,‘b‘,‘c‘] ==> {{obj[0]}} ,obj={a:‘a‘,c:‘c‘} ==>{{obj.a}}

  2.{{表達式}} 如果為angular應用程序變量名,則功能與ng-bind一樣,在html中顯示變量值。

4.angularjs應用

  1.angularjs模塊(module) 定義了angularjs應用。

  2.angularjs控制器(controller )用於控制angularjs應用

  ng-app指令定義了應用, ng-controller 定義了控制器。

  

技術分享
 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> 
 6 </head>
 7 <body>
 8 
 9   <p>嘗試修改以下表單。</p>
10 
11   <div ng-app="myApp" ng-controller="myCtrl">
12 
13   名: <input type="text" ng-model="firstName"><br>
14   姓: <input type="text" ng-model="lastName"><br>
15   <br>
16   姓名: {{firstName + " " + lastName}}
17 
18   </div>
19 
20   <script>
21   var app = angular.module(myApp, []);
22   app.controller(myCtrl, function($scope) {
23   $scope.firstName= "Joh333n";
24   $scope.lastName= "Doe";
25   });
26   </script>
27 
28 </body>
29 </html>
View Code

5.創建自定義的指令

除了 AngularJS 內置的指令外,我們還可以創建自定義指令。

你可以使用 .directive 函數來添加自定義的指令。

要調用自定義指令,HTML 元素上需要添加自定義指令名。

使用駝峰法來命名一個指令, runoobDirective, 但在使用它時需要以 - 分割, runoob-directive:

  .可以通過元素名調用指令 //restrict:"E"; E=element;

<body ng-app="myApp">

    

<body>
    <div ng-app="myApp">
        <runoob-directive></runoob-directive>
        <script>
             var app=angular.module("myApp");
             app.directive("runoobDirective",function(){
      return {template:"<h1>this is auto defined code<h1>"}
    
    });
        </script>
    </div>
</body>

通過屬性來調用//restrict:"A"; E=attribute;

<body ng-app="myApp">

<div runoob-directive></div>

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        template : "<h1>自定義指令!</h1>"
    };
});
</script>

</body>

通過類來調用

<body ng-app="myApp">

<div class="runoob-directive"></div>

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        restrict : "C",//C=class
        template : "<h1>自定義指令!</h1>"
    };
});
</script>

<p><strong>註意:</strong> 你必須設置 <b>restrict</b> 的值為 "C" 才能通過類名來調用指令。</p>

</body>

通過註釋來調用

<body ng-app="myApp">

<!-- directive: runoob-directive -->

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        restrict : "M",//M=comment
        replace : true,
        template : "<h1>自定義指令!</h1>"
    };
});
</script>

<p><strong>註意:</strong> 我們需要在該實例添加 <strong>replace</strong> 屬性, 否則評論是不可見的。</p>

<p><strong>註意:</strong> 你必須設置 <b>restrict</b> 的值為 "M" 才能通過註釋來調用指令。</p>

</body>

angularJS初學篇-1添加隨筆