AngularJs  Understanding Angular Templates


Posted in Javascript onSeptember 02, 2016

angular template是一个声明规范,与model、controller的信息一起,渲染成用户在浏览器中所看到的视图。它是静态的DOM,包括HTML、CSS、angular特别的元素和angular指定的元素属性。angular元素和属性指示angular去扩展行为以及将template DOM转换为动态视图的DOM。

下面是我们可以在template中使用的angular元素已经元素属性的类型:

  1. Directive(https://3water.com/article/91739.htm) - 一个扩展现有DOM元素或者代表一个可复用的DOM组件的属性或者元素,即控件。
  2. Markup(http://code.angularjs.org/1.0.2/docs/api/ng.$interpolate) - 通过双大括号表示法{{}}来绑定表达式到元素中,是内建的angular标记。
  3. Filter(http://code.angularjs.org/1.0.2/docs/guide/dev_guide.templates.filters)- 用于格式化我们给用户看的数据。
  4. Form controls (https://3water.com/article/91744.htm)- 让我们验证用户输入。

注意:除了可以在模版中声明上面的元素以外,我们也可以在javascript代码中访问这些元素。

下面的代码片段,展示了一个简单的angular template,它由标准的HTML标签以及angular directive、花括号绑定的expression({{expression}},https://3water.com/article/91742.htm)组成。

<!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>

在一个简单的单页应用中,模版由HTML、CSS以及angular directive组成,都包含在一个HTML文件中(通常叫它index.html)。但在一些更加复杂的应用中,我们可以在一个页面中,通过使用“partials”来显示多个视图,即将模版分段存放在独立的HTML文件中。我们可以在主页面中使用$route服务(http://code.angularjs.org/1.0.2/docs/api/ng.$route)与ngView directive(http://code.angularjs.org/1.0.2/docs/api/ng.directive:ngView)来协同“include”那些partials。这个技术的一个例子,展示在angular tutorial(http://code.angularjs.org/1.0.2/docs/tutorial/index)的第七、八步骤中。(这部分我稍后再玩-_-!)

以上就是对 AngularJs Understanding Angular Templates的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

Javascript 相关文章推荐
javascript 关闭IE6、IE7
Jun 01 Javascript
JavaScript异步调用定时方法并停止该方法实现代码
Mar 16 Javascript
Jquery中国地图热点效果-鼠标经过弹出提示层信息的简单实例
Feb 12 Javascript
node.js入门教程迷你书、node.js入门web应用开发完全示例
Apr 06 Javascript
用js闭包的方法实现多点标注冒泡示例
May 29 Javascript
解决微信内置浏览器返回上一页强制刷新问题方法
Feb 05 Javascript
集成vue到jquery/bootstrap项目的方法
Feb 10 jQuery
angularJs复选框checkbox选中进行ng-show显示隐藏的方法
Oct 08 Javascript
vue-i18n结合Element-ui的配置方法
May 20 Javascript
JS去除字符串最后的逗号实例分析【四种方法】
Jun 20 Javascript
jquery ajax 请求小技巧实例分析
Nov 11 jQuery
vue cli4中mockjs在dev环境和build环境的配置详情
Apr 06 Vue.js
jquery 中toggle的2种用法详解(推荐)
Sep 02 #Javascript
浅谈JS中的三种字符串连接方式及其性能比较
Sep 02 #Javascript
AngularJs  E2E Testing 详解
Sep 02 #Javascript
解决node.js安装包失败的几种方法
Sep 02 #Javascript
js两种拼接字符串的简单方法(必看)
Sep 02 #Javascript
AngularJs Understanding the Controller Component
Sep 02 #Javascript
JS 拼凑字符串的简单实例
Sep 02 #Javascript
You might like
海河写的 Discuz论坛帖子调用js的php代码
2007/08/23 PHP
第六章 php目录与文件操作
2011/12/30 PHP
laravel中的一些简单实用功能
2018/11/03 PHP
Thinkphp 框架扩展之数据库驱动常用方法小结
2020/04/23 PHP
JavaScript null和undefined区别分析
2009/10/14 Javascript
扩展jquery实现客户端表格的分页、排序功能代码
2011/03/16 Javascript
图片Slider 带左右按钮的js示例
2013/08/30 Javascript
jquery使用slideDown实现模块缓慢拉出效果的方法
2015/03/27 Javascript
基于JQuery的$.ajax方法进行异步请求导致页面闪烁的解决办法
2016/05/10 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
AngularJS 表达式详细讲解及实例代码
2016/07/26 Javascript
jQuery实现页面点击后退弹出提示框的方法
2016/08/24 Javascript
vuejs事件中心管理组件间的通信详解
2017/08/09 Javascript
jqgrid实现简单的单行编辑功能
2017/09/30 Javascript
js原生日历的实例(推荐)
2017/10/31 Javascript
Node.js操作MongoDB数据库实例分析
2020/01/19 Javascript
vue element-ui中table合计指定列求和实例
2020/11/02 Javascript
关于Python面向对象编程的知识点总结
2017/02/14 Python
Python正则表达式完全指南
2017/05/25 Python
Python 实现删除某路径下文件及文件夹的实例讲解
2018/04/24 Python
python elasticsearch环境搭建详解
2019/09/02 Python
Python argparse模块使用方法解析
2020/02/20 Python
Django分组聚合查询实例分享
2020/04/29 Python
如何基于Python和Flask编写Prometheus监控
2020/11/25 Python
python使用正则表达式匹配txt特定字符串(有换行)
2020/12/09 Python
两种CSS3伪类选择器详细介绍
2013/12/24 HTML / CSS
LN-CC日本:高端男装和女装的奢侈时尚目的地
2019/09/01 全球购物
单位在职证明范本
2014/01/09 职场文书
信用社员工先进事迹材料
2014/02/04 职场文书
物业管理专业自荐信
2014/07/01 职场文书
演讲稿的格式及范文
2014/08/22 职场文书
毕业证丢失证明范本
2014/09/20 职场文书
教师作风整顿个人剖析材料
2014/10/10 职场文书
2014年大学班长工作总结
2014/11/14 职场文书
python 办公自动化——基于pyqt5和openpyxl统计符合要求的名单
2021/05/25 Python
python和anaconda的区别
2022/05/06 Python