AngularJs-指令和指令之间的交互(动感超人)

前言:

  上节我们学习到了指令和控制器之间的交互,通过给指令添加动作,调用了控制器中的方法。本节我们学习指令和指令之间是如何交互的,我们通过一个小游戏来和大家一起学习,听大漠老师说这是国外的人写的demo,我们可以借鉴学习。

1,动感超人

  

上面的三个按钮,代表三个超人,在此想问下,哪些想看超人的朋友们是不是有种被骗了的感觉?

当我们的鼠标移动到哪个超人的身上的时候,就会输入这个超人所拥有的超能力(力量 + 敏捷 + 发光)

<!DOCTYPE html>
<html ng-app="MyModule">
<head><meta charset="utf-8"><link rel="stylesheet" href="css/bootstrap.min.css"><title>指令之间的交互</title>
</head>
<body><div class="row"><div class="col-md-3"><superman strength>动感超人---力量</superman></div><div class="col-md-3"><superman strength speed>动感超人2---力量+敏捷</superman></div><div class="col-md-3"><superman strength speed light>动感超人3---力量+敏捷+发光</superman></div></div>
</body>
<script src="js/angular-1.3.0.js"></script>
<script src="js/directive-directive.js"></script>
</html>

ok,我们先创建了四个指令,一个是通过 E 的模式创建的叫做 superman,另外三个是通过 A 模式创建的 (strength、speed和light)。

var myModule = angular.module('MyModule',[]);
myModule.directive('superman',function(){return{scope:{},restrict:'AE',controller:function($scope){$scope.abilities=[];this.addStrength=function(){$scope.abilities.push("strength");};this.addSpeed = function(){$scope.abilities.push('speed');};this.addLight = function(){$scope.abilities.push('light');}},link:function(scope,element,attrs){element.addClass('btn btn-primary');element.bind('mouseenter',function(){console.log(scope.abilities);})}}
});
myModule.directive('strength',function(){return{require:'^superman',link:function(scope,element,attr,supermanCtl){supermanCtl.addStrength();}}
})
myModule.directive('speed',function(){return{require:'^superman',link:function(scope,element,attr,supermanCtl){supermanCtl.addSpeed();}}
})
myModule.directive('light',function(){return{require:'^superman',link:function(scope,element,attr,supermanCtl){supermanCtl.addLight();}}
})

上面的代码,最主要的就是 superman的这个指令,里面有些我们还没有认识的元素,我们下面介绍下:

  • scope:{}这个是创建一个独立的作用域。
  • controller,这个和我们angular中的控制器有些不同,这个主要是写一些指令的对外方法。

好,我们再来介绍下面的三个指令,我们就说一个就好了,其它的都一样的。

在这三个控制器也有新增的东西:

  • require:"^superman",这个是告诉angularJS,当前的指令,依赖于哪个指令。我们现在的  strength指令依赖于superman的指令
  • link方法中的第四个参数,叫做父控制器,只要是指令写了require参数,就可以使用这个参数了,它可以访问父级contorller的方法中提供的一些属性和方法。

2,总结

  我们从代码上可以看出,我们的三个超人拥有超能力多少是和拥有的指令多少成正比的。他们都有一个父的指令,父指令提供了超能力的力量(我们可以理解为数据)。子指令控制了是否追加这些功能。

转载于:https://www.cnblogs.com/zhiyuan-2011/p/4280593.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574877.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux中有fd set函数吗,LINUX下FD_SET介绍

刚刚了解了linux下select系统调用&#xff0c;函数原型是#include #include intselect(int maxfdpl, fd_set *readset, fd_set *writeset, fd_set *exceptset, const struct timeval *timeout);如何给readset, writeset, exceptset这3个参数中的每一个参数指定一个或多个描述符…

vba 指定列后插入列_在不同的列左侧插入指定数量的空白列

任务: 在不同的列左侧插入指定数量的空白列(本例是要求在每列左侧插入第2行数字对应的空白列) 插入空白列前 插入空白列后 vba代码如下&#xff1a; Sub 在不同的列左侧插入指定数量的空白列() Dim m, n, i As Integer For n 5 To 1 Step -1 Sheets("Sheet1").C…

怎么监听linux防火墙,linux怎么查看防火墙是否开启并清除防火墙规则?

iptables是linux下的防火墙组件服务&#xff0c;相对于windows防火墙而言拥有更加强大的功能&#xff0c;下面我们就来看看linux系统中关于iptables的一般常见操作&#xff0c;判断linux系统是否启用了iptables服务&#xff0c;并清除防火墙规则的教程。一、检查iptables是否安…

手册如何看运放的db_如何处理金属离子与配体之间的配位键?

更多资讯&#xff0c;请访问www.yinfotek.com 或关注微信公众号“殷赋科技”。殷赋学术交流2群已建立&#xff0c;需求加群的朋友&#xff0c;请在公众号输入“加群”&#xff0c;验证后即入群。1A:请教大家一个问题&#xff1a;在做对接模拟的过程中蛋白活性中心存在重要金属离…

修改PHP上传文件的大小限制

Warning: POST Content-Length of 35052172 bytes exceeds the limit of 8388608 bytes in Unknown on line 0 该条警告是PHP.ini中的配置有关。 上述错误信息的大致意思是&#xff0c;我们使用POST请求提交的数据大小超过了服务器的最大限制数 出现上述错误的原因是&#xff0…

linux如何得到本机地址,Linux下如何得到本机所有IP地址及MAC地址

已知&#xff1a;gethost and gethostbyname,测试只能得到一个IP地址。---------------------------------------------------------------原文&#xff1a;http://www.chinaunix.net/jh/23/161236.html---------------------------------------------------------------整理后…

secure连不上远程地址_[笔记]Mariadb安装并配置远程访问

引言熟悉的小伙伴都知道我自用有一台NAS&#xff0c;并为此折腾了不少内容&#xff1a;西蒙宫&#xff1a;折腾&#xff0c;用J3455搭建家庭nas西蒙宫&#xff1a;让家庭NAS走向世界&#xff0c;兼谈Zerotier西蒙宫&#xff1a;折腾——组装NAS编译安装ffmpeg在NAS上部署了Next…

从Wireshark看TCP连接的建立与关闭

TCP是一种面向连接、可靠的协议。TCP连接的建立与断开&#xff0c;都是需要经过通信双方的协商。用一句话概括就是&#xff1a;三次握手say hello&#xff08;建立连接&#xff09;&#xff1b;四次握手say goodbye&#xff08;断开连接&#xff09;。要了解TCP连接的建立与断开…

linux管道通信机制有哪两种,linux的管道通信机制

弹性云服务器 ECS弹性云服务器(Elastic Cloud Server)是一种可随时自助获取、可弹性伸缩的云服务器&#xff0c;帮助用户打造可靠、安全、灵活、高效的应用环境&#xff0c;确保服务持久稳定运行&#xff0c;提升运维效率三年低至5折&#xff0c;多种配置可选了解详情什么是弹性…

python批量ping脚本_Python多线程批量Ping主机IP的脚本

Python 编写多线程 Ping 主机IP的脚本1. 先编写一个 Ping 主机IP的脚本ping_ip.pyimport subprocessimport time# 记录开始执行的时间start_time time.time()# 定义用来 ping 的254 个 ipip_list [10.3.1.str(i) for i in range(1,255)]for ip in ip_list:res subprocess.ca…

用Visual C#来清空回收站(2)

四.程序的源代码&#xff08;recycled.cs&#xff09;、编译方法及运行后的界面&#xff1a;  &#xff08;1&#xff09;.程序的源代码&#xff1a;recycled.cs&#xff1a; using System.IO ; using System.Windows.Forms ; //导入程序中用到的名称空间 class Recycle { pu…

Linux6.8 ssh开启,CentOS 6.8升级 ssh到最新版SSH-8.2p1

查看当前版本ssh -VOpenSSH_5.3p1, OpenSSL 1.0.1e-fips 11 Feb 2013有漏洞需要升级编译所需工具包yum install gcc pam-devel zlib-devel安装telnet服务 //防止远程ssh升级失败yum -y install telnet-server* telnetvim /etc/xinetd.d/telnet将disable字段的yes改为no以启用te…

jq苹果手机全屏下点击无效果_苹果系统自带外挂?无需越狱也可录制动作脚本...

网络游戏开始流行起来之后&#xff0c;随之而来的是外挂的兴起&#xff0c;各式各样的外挂中有两种最为致命&#xff1a;物理外挂和系统自带外挂。随着国内电竞行业和电竞直播的兴起&#xff0c;“物理外挂”出现在我们周围的频率也越来越高&#xff0c;比如扩大视角的显示器、…

利用cors,实现js跨域访问Tomcat下资源

第一步&#xff1a;页面js代码&#xff1a; function createCORSRequest(method, url){var xhr new XMLHttpRequest();if ("withCredentials" in xhr){xhr.open(method, url, true);} else if (typeof XDomainRequest ! "undefined"){xhr new XDomainReq…

c语言不同类型变量用什么表示什么作用,C语言数据类型及变量整理

数据类型获取int的字节数大小方法printf("int bytes:%d",sizeof(int));列表整理Int 与 long int的区别早期的C平台是16位int系统&#xff0c;int用二字节表示&#xff0c;范围是-32768~32767&#xff1b;long是long int的简写&#xff0c;用4字节表示&#xff0c;范围…

python求第n个质数_找到第n个质数:麻木

我试图用埃拉霍斯特内斯的筛子找到第n个质数。是的&#xff0c;我看到了类似的帖子&#xff0c;但是我对这段代码有一个问题。一旦找到第n个素数&#xff0c;我就停止算法。我写的是&#xff1a;def nth_prime(n):limit 10**2pn 1 #keeps track of how many prime numbers we…

python中浮点数能用乘法吗_简单讲解Python中的数字类型及基本的数学计算

Python有四种类型的数字:1.整型 a = 2 print a 2.长整型 b = 123456789 print b 3.浮点数 c = 3.2E2 print c 4.复数 复数为实数的推广,它使任一多项式都有根。复数当中有个“虚数单位”j,它是-1的一个平方根。任一复数都可表达为x+yj,其中x及y皆为实数,分别称为复数之“实…

c语言设计通讯录管理程序,C语言程序的设计学生通讯录管理系统方案.docx

include ustdio.hH include "stdlib.h” include "string.h" include "conio.h” include Mstdlib.hu ^define null 0 struct record{char namc[20];char phone[20J;char adress[40J;char postcodeflO];char c_mail[30];}sludcnt[500];struct LinkList{str…

*在通配符及正则表达式中的差别

*在通配符和正则表达式中有其不一样的地方&#xff0c;在通配符中*可以匹配任意的0个或多个字符&#xff0c;而在正则表达式中他是重复之前的一个或者多个字符&#xff0c;不能独立使用的。比如通配符可以用*来匹配任意字符&#xff0c;而正则表达式不行&#xff0c;他只匹配任…

python主成分分析实验报告_python进行主成分分析

数据&#xff1a;序号x1x2x3x414025202101.553031203135042504.518051203.59506101.512507401194082704136092803.51160101703960111803.514401213023050132201.51720141601.53560152202.514301614022020172202141018401100192011260201202200数据标准化&#xff1a;x1x2x3x40-…