zoukankan      html  css  js  c++  java
  • Angularjs基础(二)

    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只限属实使用

  • 相关阅读:
    十六、异步编程——messagedialog
    关于委托的一个摘录
    com interop 简述
    [STAThread]的使用
    Python初识和基础语法
    Python基础数据类型以及格式化输出
    JS读取PHP中设置的中文cookie时出现乱码的解决方法
    解决跨域读写Cookies的问题,(ASP、PHP、ASP.NET、JSP)解决方案
    多字段distinct查询
    Dedecms当前位置{dede:field name='position'/}修改,去掉>方法
  • 原文地址:https://www.cnblogs.com/nmxs/p/5401256.html
Copyright © 2011-2022 走看看