AngularJS 表达式
  AngularJS 表达式写在双大括号内:{{expression}}
  AngularJS 表达式把数据绑定到HTML,这与ng-bind 指令有异曲同工之妙
  AngularJS 将在表达式书写的位置输出数据。
  AngularJS 表达式很像JavaScript表达式:他们可以包含文字,运算符和变量。
    实例{{5+5}} 或者{{firstName + "" +lastName}}

AngularJs 数字
  AngularJS 数字就像JavaScript 数字:
    实例:
      <div ng-app="" ng-init="quantity=1;cost=5">
        <p>总价:{{quantity * cost}}</p>
      </div>
    使用 ng-bind 的相同实例:
      <div ng-app="" ng-init="quantity=1;cost=5">
          <p>总价:<span ng-bind="quantity * cost"></span></p>
      </div>
  使用 ng-init 不是很常见。您将在控制器一章中学习到一个更好的初始化数据的方式。

AngularJS 字符串
  Angular字符串就像JavaScript字符串:
    实例:
      <div ng-app"" ng-init="firstName='John';lastName='Doe'">
          <p>姓名:{{firsName +""+lastName}}</p>
      </div>
    使用ng-bind的相同实例
      <div ng-app="" ng-init="firstName='John';lastName='Doe'">
          <p>姓名:<span ng-bind="firstName +' '+lastName"></span></p>
      </div>

AngularJs对象
   AngularJs对象就像javaScript 对象
      实例:
        <div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}">
            <p>姓为{{person.lastName}}</p>
        </div>
      使用ng-bind的相同实例
         <div ng-app="" ng-init="person={firstName:'John',lastName:'Doe'}">
            <p>姓为<span ng-bind="person.lastName"></span></p>
          </div>

AngularJs数组
    AngularJs数组就像JavaScript数组:
      实例:
        <div ng-app="" ng-init="points=[1,15,19,2,40]">
            <p>第三个值为{{points[2]}}</p>
        </div>
    使用ng-bind的相同实例
        <div ng-app="" ng-init="points=[1,15,19,2,40]">
          <p>第三个值为<span ng-bind="points[2]"></span></p>
        </div>
    AngularJs 表达式 与JavaScript表达式
      类似于javaScript 表达式,AngularJS表达式可以包含字母,操作符,变量。
      与JavaScript表达式不同,AngularJs表达式可以写在HTML中,表达式不支持判断条件,循环及异常
      表达式不支持过滤器。

AngularJS指令
    AngularJS通过被称为指令的新属性来扩展HTML,带有前缀 ng-。
    AngularJs通过内置的指令来为应用添加功能,ng-app 指令初始化一个 AngularJS 应用程序.
    AngularJs允许你自定义指令。
    ng-init指令初始化应用程序数据。
    ng-model指令把元素值(比如输入域的值)绑定到应用程序
      实例:
          <div ng-app="" ng-init="firstName='John'">
            <p>在输入框中常识输入:</p>
            <p>姓名:<input type="text" ng-model="firstName"></p>
            <p>你输入的为:{{firstName}}</p>
          </div>
    ng-app 指令告诉AngularJS<div>元素是AngularJS 应用程序的拥有者。
    一个网页可以包含多个运行在不同元素中的 AngularJS 应用程序。

数据绑定
    上面实例中的{{firstName}}表达式是一个AngularJS数据的绑定的表达式。
    AngularJS中的数据绑定,同步了AngularJS表达式月AngularJS数据
      {{firstName}} 是通过ng-model="firstNmae"进行同步。
    在下一个实例中,两个文本域是通过两个ng-model指令同步的。
      实例:
          <div ng-app="" ng-init="quantity=1; price=5">
              <h2>价格计算器</h2>
              数量:<input type="number" ng-model="quantity">
              价格:<input type="number" ng-model="price">
              <p><b>总价:</b>{{quantity * price}}</p>
          </div>

重复HTML元素
    ng-repeat指令会重复一个HTML
      实例:
        <div ng-app="" ng-init="names=['Jani','Hege','Kai']">
            <p>使用ng-repeat 来循环数组</p>
            <ul>
              <li ng-repeat="x in name">
                  {{X}}
              </li>
          </ul>
        </div>
    ng-repeat 指令用在一个对象数组上
        实例:
          <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 name">
                      {{x.name + ',' + x.country}}
                    </li>
                </ul>
          </div>

ng-app 指令
      ng-app指令定义了AngularJS 应用程序的 根元素。
      ng-app 指令在网页加载完毕时会自动引导(自动初始化)应用程序
ng-init 指令
      ng-init指令为AngularJS 应用程序定义了初始值。
      通常情况下,不适用ng-init,您将使用一个控制器或模块来代替她。
ng-model指令
      ng-model指令绑定HTML元素到应用程序。
      ng-model 指令也可以
      为应用程序数据提供类型验证(number,email, required).
      为应用程序数据提供状态(invalid,dirty,touched,error)
      为HTML 元素提供CSS 类
      绑定到HTML元素到HTML表单

ng-repeat 指令
    ng-repeat指令对于集合中(数组中)的每个项会克隆一次HTML元素

创建自定义的指令
    除了AngularJS内置的指令外,我们还可以创建自定义指令。
    你可以使用.directive函数来添加自定义的指令。
    要调用自定义指令,HTML元素张需添加自定义指令名。
    使用驼峰命名法来命名一个指令,runoobDirective,但在使用它时需要以-分割,runoob-directive
      实例:
        <body ng-app="myApp">
            <runoob-directive></runoob-directive>
            <script>
                var app = angular.module("myApp",[])l
                app.directive("runoobDirective",function(){
                return{
                    template:"<h1>自定义指令!</h1>"
                };
              })
            </script>
        </body>
    可以通过以下方式来调用指令:
        元素名:<runoob-directive></runoob-directive>
        属性:<div runoob-directive></div>
        类名:<div class="runoob-directive"></div>
        注释:<!-- 指令: runoob-directive-->

限制使用
    你可以限制你的指令只能通过特定的方式来调用。
      实例:
        通过添加 restrict 属性,并设置只值为 "A", 来设置指令只能通过属性的方式来调用:
        var app = angular.module("myApp",[]);
        app.directive("runoobDirective",function(){
        return{
            restrict:"A",
            template:"<h1>自定义</h1>"
          }
      })
      restrict 值可以是以下几种
        E只限元素名使用
        A只限属性使用
        C只限类名使用
        M只限属实使用

Angularjs基础(二)的更多相关文章

  1. AngularJS基础入门初探

    一.AngularJS简介 1.1 什么是AngularJS (1)一款非常优秀的前端JS框架,可以方便实现MVC/MVVM模式 (2)由Misko Hevery 等人创建,2009年被Google所 ...

  2. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  3. Bootstrap <基础二十九>面板(Panels)

    Bootstrap 面板(Panels).面板组件用于把 DOM 组件插入到一个盒子中.创建一个基本的面板,只需要向 <div> 元素添加 class .panel 和 class .pa ...

  4. Bootstrap <基础二十八>列表组

    列表组.列表组件用于以列表形式呈现复杂的和自定义的内容.创建一个基本的列表组的步骤如下: 向元素 <ul> 添加 class .list-group. 向 <li> 添加 cl ...

  5. Bootstrap<基础二十七> 多媒体对象(Media Object)

    Bootstrap 中的多媒体对象(Media Object).这些抽象的对象样式用于创建各种类型的组件(比如:博客评论),我们可以在组件中使用图文混排,图像可以左对齐或者右对齐.媒体对象可以用更少的 ...

  6. Bootstrap <基础二十六>进度条

    Bootstrap 进度条.在本教程中,你将看到如何使用 Bootstrap 创建加载.重定向或动作状态的进度条. Bootstrap 进度条使用 CSS3 过渡和动画来获得该效果.Internet ...

  7. Bootstrap <基础二十五>警告(Alerts)

    警告(Alerts)以及 Bootstrap 所提供的用于警告的 class.警告(Alerts)向用户提供了一种定义消息样式的方式.它们为典型的用户操作提供了上下文信息反馈. 您可以为警告框添加一个 ...

  8. Bootstrap<基础二十四> 缩略图

    Bootstrap 缩略图.大多数站点都需要在网格中布局图像.视频.文本等.Bootstrap 通过缩略图为此提供了一种简便的方式.使用 Bootstrap 创建缩略图的步骤如下: 在图像周围添加带有 ...

  9. Bootstrap <基础二十三>页面标题(Page Header)

    页面标题(Page Header)是个不错的功能,它会在网页标题四周添加适当的间距.当一个网页中有多个标题且每个标题之间需要添加一定的间距时,页面标题这个功能就显得特别有用.如需使用页面标题(Page ...

随机推荐

  1. 一个简单问题引发对IEnumerable和IQueryable的思考

    问题概述:    首先看下图,有客户表和客户负责人表关系是多对多,访问数据库使用的是EF所以这里我们开启了延迟加载,需求就是将每个客户的所有负责人逗号拼接显示在负责人这一栏位, 对你没看错需求就是这么 ...

  2. 项目管理系统 TAIGA 部署

    题记 使用了 MantisBT 一段时间,觉得功能太少,只局限在错误跟踪,而且操作体验比较差,界面很糟糕,很早就想将其换掉. 偶然发现一个很不错的新选择:Taiga,于是就试着将其部署下来,发现绝对是 ...

  3. 利用ajax短轮询+php与服务器交互制作简易即时聊天网站

    主流的Web端即时通讯方案大致有4种:传统Ajax短轮询.Comet技术.WebSocket技术.SSE(Server-sent Events). 本文主要介绍ajax短轮询的简易实现方式. 看懂此文 ...

  4. OLEDB 参数化查询

    一般情况下,SQL查询是相对固定的,一条语句变化的可能只是条件值,比如之前要求查询二年级学生信息,而后面需要查询三年级的信息,这样的查询一般查询的列不变,后面的条件只有值在变化,针对这种查询可以使用参 ...

  5. OpenStack各组件详解和通信流程

    一.openstack由来 openstack最早由美国国家航空航天局NASA研发的Nova和Rackspace研发的swift组成.后来以apache许可证授权,旨在为公共及私有云平台建设.open ...

  6. 文章点赞功能(Ajax)

    一.文章点赞样式构建 1.将base.html的css样式改为外部引入 将base.html的内嵌样式删除,改为使用 HTML 头部的 <head> 标签对中使用<link>标 ...

  7. Android使用Gradle命令动态传参完成打包,不需要修改代码

    不得不说,Gradle很强大,有人会问Gradle是什么?这里也不细讲,在我认为他就是一个构建神器.Gradle 提供了: 一个像 Ant 一样的非常灵活的通用构建工具 一种可切换的, 像 Maven ...

  8. PowerDesigner 连接数据库(以MySQL)为例

  9. oracle_union_operator

    SQL: UNION Operator This SQL tutorial explains how to use the SQL UNION operator with syntax and exa ...

  10. FPGA----只读存储器(ROM)

            ROM是一种重要的时序逻辑存储电路,它的逻辑功能是在地址信号的选择下,从指定存储单元中读取相应的数据.R0M只能进行数据的读取,而不能修改或写人新的数据,本节将以16×8的ROM为例, ...