AngularJs學習筆記--Understanding Angular Templates


原版地址:http://docs.angularjs.org/guide/dev_guide.mvc.understanding_model

 

  angular template是一個聲明規范,與modelcontroller的信息一起,渲染成用戶在瀏覽器中所看到的視圖。它是靜態的DOM,包括HTMLCSSangular特別的元素和angular指定的元素屬性。angular元素和屬性指示angular去擴展行為以及將template DOM轉換為動態視圖的DOM

  下面是我們可以在template中使用的angular元素已經元素屬性的類型:

  • Directivehttp://www.cnblogs.com/lcllao/archive/2012/09/09/2677190.html) 一個擴展現有DOM元素或者代表一個可復用的DOM組件的屬性或者元素,即控件。
  • Markuphttp://code.angularjs.org/1.0.2/docs/api/ng.$interpolate) 通過雙大括號表示法{{}}來綁定表達式到元素中,是內建的angular標記。
  • Filterhttp://code.angularjs.org/1.0.2/docs/guide/dev_guide.templates.filters用於格式化我們給用戶看的數據。
  • Form controls http://www.cnblogs.com/lcllao/archive/2012/09/17/2688127.html讓我們驗證用戶輸入。

  注意:除了可以在模版中聲明上面的元素以外,我們也可以在javascript代碼中訪問這些元素。

  下面的代碼片段,展示了一個簡單的angular template,它由標准的HTML標簽以及angular directive、花括號綁定的expression{{expression}}http://www.cnblogs.com/lcllao/archive/2012/09/16/2687162.html)組成。

<!DOCTYPE html>
<!--ng-app,定義應用范圍,在這里創建root scop-->
<html ng-app>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>template</title>
    <meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
    <style type="text/css">
        .ng-cloak {
            display: none;
        }
    </style>
</head>
<!--
    ng-cloak,在編譯后會去掉的class
    ng-controller,一個directive,用於指定當前的模版對應的Controller為MyController
-->
<body class="ng-cloak" ng-controller="MyController">

<!--
    ng-model,directive,用於指定input的值對應的model為foo。
-->
<input type="text" ng-model="foo" value=""/>
<!--
    ng-click,directive,單擊后需要做的事情,可以是expression,如 buttonText = '1';
    也可以是調用函數,如下面所示。
    {{buttonText}},用於展示當前scope鏈中能夠或得到的buttonText的值
-->
<button ng-click="changeFoo()">{{buttonText}}</button>

<script src="../angular-1.0.1.js" type="text/javascript"></script>
<script type="text/javascript">
    function MyController($scope) {
        $scope.buttonText = "默認的東東";//初始化model buttonText
        $scope.foo = "修改我吧";//初始化model foo
        $scope.changeFoo = function() {//聲明changeFoo
            this.buttonText = this.foo;//將foo的值賦給buttonText
            //這里使用的this,就是指向當前$scope的。
        };
    }
</script>
</body>
</html>

 

  在一個簡單的單頁應用中,模版由HTMLCSS以及angular directive組成,都包含在一個HTML文件中(通常叫它index.html)。但在一些更加復雜的應用中,我們可以在一個頁面中,通過使用“partials”來顯示多個視圖,即將模版分段存放在獨立的HTML文件中。我們可以在主頁面中使用$route服務(http://code.angularjs.org/1.0.2/docs/api/ng.$route)與ngView directivehttp://code.angularjs.org/1.0.2/docs/api/ng.directive:ngView)來協同“include”那些partials。這個技術的一個例子,展示在angular tutorialhttp://code.angularjs.org/1.0.2/docs/tutorial/index)的第七、八步驟中。(這部分我稍后再玩-_-!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM