博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Angularjs基础(二)
阅读量:6225 次
发布时间:2019-06-21

本文共 5006 字,大约阅读时间需要 16 分钟。

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

转载于:https://www.cnblogs.com/nmxs/p/5401256.html

你可能感兴趣的文章
弃2.4GHz!这就是全新Wi-Fi标准802.11ax
查看>>
BDaas “大数据即服务”的时代即将到来?
查看>>
大数据十大核心问题
查看>>
怎样说服管理者为新的网络产品埋单?
查看>>
SSH如何通过公钥连接云服务器
查看>>
索尼影业就是被这两款工具黑的
查看>>
我想对所有新程序员说的一些话
查看>>
在终端中优雅地编写Python
查看>>
盘点56个最实用的大数据可视化分析工具
查看>>
福布斯评出最热门的 10 大 AI 技术,以及面临的问题
查看>>
2017年成为Linux专家的4个热门技能
查看>>
骑车 or 开车,一个钥匙架想通过暗示改变你的生活习惯
查看>>
数据中心真的是耗能大户?只占十分之一
查看>>
智慧城市将推动产品更新换代 专家:政府公共管理与市场化需有效协调
查看>>
自成咨询:当管理会计遇上大数据
查看>>
SDN和数据中心蜜月后还能做点啥
查看>>
浅谈云计算技术原理和体系结构
查看>>
《UX最佳实践:提高用户体验影响力的艺术 》一3.3 工作流程中各个角色的密切配合使用户体验达到更好效果...
查看>>
西数打造面向数据中心的Gold产品组合
查看>>
俄公司将为“物联网”部署约200颗卫星
查看>>