您好,接着在昨天对简单指令学习了解以后,今天开始学习了解angularjs中的系统指令

  系统指令大部分都是以ng开始,这也是为什么在自定义指令命名时不要以ng开始的原因所在

  系统指令在学习了分成两个部分进行学习:基础指令、在指令中使用子作用域

  第一、基础指令

    基础指令由包括bool型和类bool型两类

    bool型指令,就是其值是一bool值(true or false)

    1.1、bool指令包括:

    ng-disabled:主要控制控件是否可操作

    ng-readonly:控制文本输入框为只读

    ng-check:控制选择框是否被选中

    ng-selected:控制下拉框选中项

    1.2、类布尔指令包括:

    ng-href 指令:与html中的href对应,其好处是当为给其赋值时

    ng-src指令:与html中的src对应,表达式生效之前不要加载图像:

    一个简单的练习:

    

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body ng-app="myApp" ng-controller="myContro">
<div>
<h1> ng-disabled指令</h1>
<input type="text" ng-disabled="isDisable" placeholder="3s后我才可操作" />
</div> <div>
<h1> ng-readonly指令</h1>
<input type="text" ng-model="isReadonly" placeholder="只要我不空下面就不可操作" />
<input type="text" ng-readonly="isReadonly" placeholder="前面不为空我就不可操作啦" />
</div> <div>
<h1> ng-check指令</h1>
是否选中王先生<input type="checkbox" ng-model="isSelected" value="是否选中王先生" />
<select>
<option>许先生</option>
<option ng-selected="isSelected">王先生</option>
</select>
</div>
</body>
</html>
<script src="Scripts/angular.js"></script>
<script type="text/javascript">
var app = angular.module("myApp", []);
app.controller("myContro", function ($scope, $timeout) {
$scope.isDisable = true;
$timeout(function () {
///// 3秒后开启控件可操作
$scope.isDisable = false;
}, 3000)
});
</script>

    

    第二、在指令中使用子作用域 

      指令中使用子作用域,其简单的理解就是,其指令会创建一个隔离的作用子域,基础父作用域。

      1、ng-app:DOM元素将被标记为$rootScope的起始点

         在JavaScript代码中通过run方法来访问$rootScope。

      2、ng-controller:控制器,创建一个子域

      3、ng-include :其实现功能效果就是,模块化加载外部的模块

       使用注意要点:

        a.ng-include,如果单纯指定地址,必须要加引号

        b.ng-include,加载外部html,script标签中的内容不执行,不能加载,如果需要控制器处理需要在主页中注册

        c.ng-include,加载外部html中含有style标签样式可以识别

        d. ng-inclue,记载外部html中的link标签可以加载

       使用距离:

        <div ng-include="/myTemplateName.html"

          ng-controller="MyController"

          ng-init="name = 'World'">

          Hello {{ name }} </div>

      4、ng-switch :根据条件选择性的加载

        格式为:ng-switch on="名称"

            ng-switch-default:默认处理

            ng-switch-when='具体的值'

        来一个练习:      

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body ng-app="myApp" ng-controller="myContro">
<div>
<h1> ng-switch指令</h1>
<select ng-model="selectValue">
<option value="">请选择</option>
<option value="xu">许先生</option>
<option value="wang">王先生</option>
</select>
<div ng-switch on="selectValue">
<div ng-switch-default>请先选择</div>
<div ng-switch-when="xu">你选择的许先生</div>
<div ng-switch-when="wang">你选择的王先生</div>
</div>
</div>
</body>
</html>
<script src="Scripts/angular.js"></script>
<script type="text/javascript">
var app = angular.module("myApp", []);
</script>

  5、ng-if :根据条件选择性的是否加载

   ng-if和ng-show、ng-hide都能够实现标签的显示隐藏

   但是其有本质的区别,ng-if是直接不加载,而后者是通过css样式控制

   代码实例:

    <div>

      <h1> ng-if指令</h1>
      是否显示<input type="checkbox" ng-model="isShow" />
      <div ng-if="isShow">
        需要显示还是隐藏我,你们自己控制吧!
      </div>
    </div>

  6、ng-repeat:循环遍历一个集合数据,根据模板生成数据列

    几个关键属性值: 

    $index:遍历的进度(0...length-1)
    $first:当元素是遍历的第一个时值为true
    $middle:当元素处于第一个和后元素之间时值为true
    $last:当元素是遍历的后一个时值为true
    $even:当$index值是偶数时值为true
    $odd:当$index值是奇数时值为true

    ng-repeat在数据列表显示中用的比较多,在实际使用中可以根据其关键字进行样式设置展示

    特别说明:集合数据的开始坐标是0,所以在处理奇偶数时要注意

    来一个练习:

    

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body ng-app="myApp" ng-controller="myContro">
<style type="text/css">
.even {
background-color: #b6ff00;
} .odd {
background-color: #808080;
}
</style> <div>
<h1>ng-repeat指令</h1>
<div ng-repeat="user in uesrList">
<div style="width:400px;height:40px;line-height:40px;" ng-class="even:!$even;odd:!odd">您好{{user.name}}</div>
</div>
<div>
姓名:<input type="text" ng-model="addName" placeholder="请输入新增的姓名" /><br />
<input type="button" ng-disabled="!addName" value="新增" ng-click="addNewName()" />
</div>
</div> </body>
</html>
<script src="Scripts/angular.js"></script>
<script type="text/javascript">
var app = angular.module("myApp", []);
app.controller("myContro", function ($scope, $timeout) {
$scope.addName = "";
$scope.uesrList = [{ name: "许先生" }, { name: "赵先生" }, { name: "刘先生" },]
$scope.addNewName = function () {
$scope.uesrList.push({ name: $scope.addName });
};
});
</script>

  

  7、{{}}与ng-bind指令:两个指令都是实现数据绑定

   区别:由于{{}}绑定数据时,会因为加载后未渲染属性而导致浏览器闪烁,ng-bind不会闪烁

      ng-bind只能执行单个变量绑定

        但是可以借助:ng-bind-template定义一个模板实现多变量绑定

        如:<h1 ng-bind-template ="{{text}} {{text}}" ></h1>

    今天就到此为止,明天继续研究指令的生深入研究学习

angularjs学习第七天笔记(系统指令学习)的更多相关文章

  1. Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer

    原文:Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处 ...

  2. Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search)

    原文:Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...

  3. iOS 阶段学习第七天笔记(函数、递归)

     iOS学习(C语言)知识点整理笔记 一.函数 1)概念:具有特定功能的代码块的封装 2)函数的定义: 函数类型+函数名(形参列表) 函数类型 函数名(形参类型1  形参名1,形参类型2   形参名2 ...

  4. 【数据库】7.0 MySQL入门学习(七)——MySQL基本指令:帮助、清除输入、查询等

    1.0 help == ? 帮助指令,查询某个指令的解释.用法.说明等.详情参考博文: [数据库]6.0 MySQL入门学习(六)——MySQL启动与停止.官方手册.文档查询 https://www. ...

  5. JAVA GUI学习 - JFileChooser文件选择器组件学习:未包括JFileChooser系统类学习

    public class JFileChooserKnow { /** * @param args */ public static void main(String[] args) { // TOD ...

  6. angularjs学习第八天笔记(指令作用域研究)

    您好,在前两天对指令的简单了解和系统指令学习后 今天主要研究其指针作用域的相关事情 每一个指令在创建时,其实就构成了自己的一个小的模块单元. 其对于的模块单元都有着其对于的作用域,其中作用域一般有两种 ...

  7. angularjs学习第六天笔记(指令简介学习)

    您好,由于周末有事情,没哟学习angularjs,几天晚上开始继续学习angularjs,坚持加油每一天.谢谢 接着上周五学习了表单验证以后,今天开始学习angularjs中一个非常重要的模块:指令 ...

  8. angularjs学习第五天笔记(第二篇:表单验证升级篇)

    您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点 ...

  9. 重温JSP学习笔记--三大指令九大内置对象

    最近在温习javaweb的相关基础知识,鉴于我弄丢了记满了整整一本的笔记,决定以后把笔记和一些学习上的心得以及碰到的一些问题统统都放在网上,今天看了一下jsp的相关基础,以下是笔记: JSP三大指令: ...

随机推荐

  1. java.security.SecureRandom源码分析 java.security.egd=file:/dev/./urandom

    SecureRandom在java各种组件中使用广泛,可以可靠的产生随机数.但在大量产生随机数的场景下,性能会较低. 这时可以使用"-Djava.security.egd=file:/dev ...

  2. 第一节20181109 《Linux就该这么学》

    在网上发现了刘老师的linux课程,关注了一段时间感觉很好就在10月1日活动日报了第19期的班,希望自己能坚持下来学好linux.

  3. WPF学习笔记(6):DataSet更新后台数据库个别列失败的问题

    WPF窗体中建有一个DataGrid,运行后修改各行数据,通过Update方法更新后台数据库.发现在数据库中,其中一列FAcctID(文本型)每次都会变为0,还有一列FDebit(货币型)不能更新,其 ...

  4. linux 下动态链接实现原理

    符号重定位 讲动态链接之前,得先说说符号重定位. c/c++ 程序的编译是以文件为单位进行的,因此每个 c/cpp 文件也叫作一个编译单元(translation unit), 源文件先是被编译成一个 ...

  5. Javascript模式小记(一)

    js总是可以在不知不觉中地创建了全局变量,其原因在于JavaScript的两个特性. 1.JavaScript可直接使用变量,甚至无需声明: 2.JavaScript有个暗示全局变量的概念,即任何变量 ...

  6. python中stack在实际中的简单应用之平衡符号

    很多书籍都在讲stack的概念和使用方法,等我们把概念熟悉后,发现不知道在什么场景下使用 该结构体,这里就列几个实用的例子,让大家了解一下stack在实际中的用处和厉害之处. 由于stack中的特点是 ...

  7. Spring Boot 1.5.10 发布:修复重要安全漏洞!!!

    2018/01/31,Spring Boot团队发布了Spring Boot 1.5.10. Maven: <parent> <groupId>org.springframew ...

  8. org.springframework.web.servlet.mvc.multiaction.NoSuchRequestHandlingMethodException

    相信很多的朋友在开发过程中都或多或少的遇见一些异常,下面我给大家说一说NoSuchRequestHandlingMethodException 这个异常说的是找不到处理这样的请求方法,那是什么原因导致 ...

  9. jsp和servlet的关系

    JSP是Servlet技术的扩展,本质上就是Servlet的简易方式.JSP编译后是“类servlet”. Servlet和JSP最主要的不同点在于:Servlet的应用逻辑是在Java文件中,并且完 ...

  10. 安装Elasticsearch中Head插件并使用

    基础环境 Elasticsearch集群搭建请参考前一篇文章http://www.cnblogs.com/aubin/p/8012840.html 系统 节点名 IP 软件版本 CentOS7.3 e ...