zoukankan      html  css  js  c++  java
  • AngularJs开发——指令与控制器间的通信

    (原文:http://www.html5jscss.com/controller-between-directive.html)

    指令与控制器之间通信,跟控制器间的通信指令间通信也类似,也是下几种方法:

    1. 通过指令自身参数
    2. 基于event传播的方式
    3. service的方式

    通过指令自身参数来共享对象、共享方法

    首先我们必须得清楚,每一个 $scope 都是scope的一个事例,而通过绑定将数据绑定在 $scope 就能实现双向绑定。scope的层次结构跟controller相关,继承关系跟又遵循了原型继承的规则,而子controller所初始化的scope是创建一个新的变量,而不是去修改父controller中的值。所以就不难使用为什么不使用基本类型变量而是使用引用类型变量去实现控制器间的通信。

    指令中怎么创建 scope:

    • scope默认值是false,表示scope跟父controller的scope相同
    • scope:true,表示创建一个继承自父scope的新scope,这样就可以让同一个父控制下的指令都可以使用这个scope进行通信。
    • 创建完全独立的属于指令自己的scope,这样可以防止读取和修改父级scope的数据。

    创建完全独立的scope的API:

    • =:提供一个与父scope的双向绑定的属性。
    • &:能够在指令内访问定义在父scope注册的函数。
    • @:提供一个 父scope-》子指令的单向绑定的属性。

    双向数据绑定DEMO(http://jsbin.com/xodebe/2/edit?html,js,output)。

    通过服务

    通过 services 实现控制器与指令双向通信,也比较简单,DEMO(http://jsbin.com/zaloj/5/edit?html,js,output)

    基于event传播的方式

    使用基于event来让控制器跟指令通信,指令中的 scope 就不能设置为独立的了,所以编写指令最好不要使用此方法。

    DEMO(http://jsbin.com/makoxo/6/edit?html,js,output)

    其实跟控制器通信中基于event传播原理是一样,只是把controller中的代码写在了diresctive中的controller中而已。

    通过三种方法比较:个人比较推荐方法一中的创建独立scope。因为这样既不会污染其他scope,也能够一眼就能看出来该指令需要从外部scope得到方法或者属性。对于方法二个人觉得用在初始化还是挺不错的。对于方法三则不很不推荐。

  • 相关阅读:
    ubuntu 16.04 网络配置之虚拟网卡的配置
    rabbitmq集群节点操作
    Ubuntu system zabbix-server-3.x install documentation
    PS RSS
    proxy_set_header设置Host为$proxy_host,$host与$local_host的区别
    centos 7 free 字段含义
    Linux atop 监控系统状态
    谨慎调整内核参数:vm.min_free_kbytes
    nginx反向代理http与https两种协议配置简述
    Python 获取以毫秒为单位的时间戳
  • 原文地址:https://www.cnblogs.com/yanxinhua/p/6120945.html
Copyright © 2011-2022 走看看