AngularJs Understanding Angular Templates
angulartemplate是一个声明规范,与model、controller的信息一起,渲染成用户在浏览器中所看到的视图。它是静态的DOM,包括HTML、CSS、angular特别的元素和angular指定的元素属性。angular元素和属性指示angular去扩展行为以及将templateDOM转换为动态视图的DOM。
下面是我们可以在template中使用的angular元素已经元素属性的类型:
- Directive(https://www.nhooo.com/article/91739.htm)-一个扩展现有DOM元素或者代表一个可复用的DOM组件的属性或者元素,即控件。
- Markup(http://code.angularjs.org/1.0.2/docs/api/ng.$interpolate)-通过双大括号表示法{{}}来绑定表达式到元素中,是内建的angular标记。
- Filter(http://code.angularjs.org/1.0.2/docs/guide/dev_guide.templates.filters)-用于格式化我们给用户看的数据。
- Formcontrols(https://www.nhooo.com/article/91744.htm)-让我们验证用户输入。
注意:除了可以在模版中声明上面的元素以外,我们也可以在javascript代码中访问这些元素。
下面的代码片段,展示了一个简单的angulartemplate,它由标准的HTML标签以及angulardirective、花括号绑定的expression({{expression}},https://www.nhooo.com/article/91742.htm)组成。
<!DOCTYPEhtml>
<!--ng-app,定义应用范围,在这里创建rootscop-->
<htmlng-app>
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<title>template</title>
<metacontent="IE=edge,chrome=1"http-equiv="X-UA-Compatible">
<styletype="text/css">
.ng-cloak{
display:none;
}
</style>
</head>
<!--
ng-cloak,在编译后会去掉的class
ng-controller,一个directive,用于指定当前的模版对应的Controller为MyController
-->
<bodyclass="ng-cloak"ng-controller="MyController">
<!--
ng-model,directive,用于指定input的值对应的model为foo。
-->
<inputtype="text"ng-model="foo"value=""/>
<!--
ng-click,directive,单击后需要做的事情,可以是expression,如buttonText='1';
也可以是调用函数,如下面所示。
{{buttonText}},用于展示当前scope链中能够或得到的buttonText的值
-->
<buttonng-click="changeFoo()">{{buttonText}}</button>
<scriptsrc="../angular-1.0.1.js"type="text/javascript"></script>
<scripttype="text/javascript">
functionMyController($scope){
$scope.buttonText="默认的东东";//初始化modelbuttonText
$scope.foo="修改我吧";//初始化modelfoo
$scope.changeFoo=function(){//声明changeFoo
this.buttonText=this.foo;//将foo的值赋给buttonText
//这里使用的this,就是指向当前$scope的。
};
}
</script>
</body>
</html>
在一个简单的单页应用中,模版由HTML、CSS以及angulardirective组成,都包含在一个HTML文件中(通常叫它index.html)。但在一些更加复杂的应用中,我们可以在一个页面中,通过使用“partials”来显示多个视图,即将模版分段存放在独立的HTML文件中。我们可以在主页面中使用$route服务(http://code.angularjs.org/1.0.2/docs/api/ng.$route)与ngViewdirective(http://code.angularjs.org/1.0.2/docs/api/ng.directive:ngView)来协同“include”那些partials。这个技术的一个例子,展示在angulartutorial(http://code.angularjs.org/1.0.2/docs/tutorial/index)的第七、八步骤中。(这部分我稍后再玩-_-!)
以上就是对AngularJsUnderstandingAngularTemplates的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!