angularJs 自定义指令传值---父级与子级之间的通信
angularJs自定义指令用法我忽略,之前有写过,这里只说一下父子级之间如何传值;
例如:
模块我定义为myApp,index.html定义 <my-html bol-val="bolVal"></my-html>,index的controller定义为myAppCtrl;
js: angular.module('app.myApp')
.controller('myAppCtrl',['$scope','myService',myAppCtrl])
.service('myService',function(){
var obj = {};
this.setValue = function(key,value){
obj[key] = value;
};
this.getValue = function(key){
return obj[key];
};
this.clearValue = function(key){
delete obj[key]
};
}) //这个比较关键
.directive('myHtml',function(){
function myHtmlCtrl($scope,myService){
//子页面逻辑
$scope.myFn=function(){
alert('Hello Word!');
};//假设有这样一个函数
(1)父级给子级传过来的值console.log($scope.bolVal);
(2)子级要传给父级的值,例如要传一个变量$scope.isShow = true,
则这样设置:myService.setValue('isShow',$scope.isShow)//变量名称可以自己定义,我为了方便还直接取了isShow;
}
return {
restrict: 'E',
replace: true,
scope:{
bolVal:'=' //有时这个值不一定拿得到,是因为嵌套层级太多,需要传过去一个对象才能拿到,看情况而定,如果父级传过来是个函数,那用“&”
},
templateUrl:'app/myapp/myhtml.html',//子级html文件所在路径
controller:['$scope','myService',myHtmlCtrl],
controllerAs:'vm',
link: function ($scope,element,attrs) {
//link函数这里主要进行dom操作
(1)第一种:可以调用子级的方法。我这里是监听传过来值的变化对这个子页面进行dom操作
$scope.$watch('bolVal', function (nwVal, odVal) {
if (nwVal != odVal) {
$scope.myFn();
}
});
(2)第二种:可以灵活调用父级方法。
这里link可以做很多事情,我就不多说了,可以多找几个例子看看!
}
};
});
index页面controller逻辑
function myAppCtrl($scope,myService){
//业务逻辑
(1)父传子:
如果index页面有一个$scope.bolVal = true值;我想要传到子页面myhtml.html中,
那很简单如上写法页面里定义bol-val="bolVal",切记:遇到大写的一定加“-”并改为小写,
directive return 对象scope里bolVal:"="
(2)子传父:
如果myhtml页面中有一个值想要传到index页面,那就比较复杂,angularJs用法还是比较灵活的,
可以写一个service服务两个controller中分别注入,例如定义为myService,如上;
这时,在子页面myhtml的controller里边设置要传的值,在父页面获取传过来的值;
父页面取值,注意一点:这个值有可能会保存到本地,所以设置之前要先清除:
myService.clearValue('isShow');
myService.getValue('isShow');
}
angularJs 自定义指令传值---父级与子级之间的通信的更多相关文章
- vue $emit 父组件与子组件之间的通信(父组件向子组件传参)
1.首先新建一个子页面为 env.vue的文件(名字这里大家可以自取) 2.然后把子页面引入父页面,代码如图: import env from '@/components/common/env' ex ...
- Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
Vue父子组件通信(父级向子级传递数据.子级向父级传递数据.Vue父子组件存储到data数据的访问) 一.父级向子级传递数据[Prop]: ● Prop:子组件在自身标签上,使用自定义的属性来接收外界 ...
- 浅析AngularJS自定义指令之嵌入(transclude)
AngularJS自定义指令的嵌入功能与vue的插槽十分类似,都可以实现一些自定义内容展现.在开始之前先简单介绍下自定义指令的transclude属性和AngularJS的内置指令ng-transcl ...
- AngularJs自定义指令详解(1) - restrict
下面所有例子都使用angular-1.3.16.下载地址:http://cdn.bootcss.com/angular.js/1.3.16/angular.min.js 既然AngularJs快要发布 ...
- AngularJS: 自定义指令与控制器数据交互
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- angularjs自定义指令Directive
今天学习angularjs自定义指令Directive.Directive是一个非常棒的功能.可以实现我们自义的的功能方法. 下面的例子是演示用户在文本框输入的帐号是否为管理员的帐号"Adm ...
- js input复选框选中父级同时子级也选中
js实现复选框选中父级元素子级元素也选中,没有子级元素选中父级也不选中的效果 HTML <tr> <td> <label> <input name=" ...
- js父页面和子页面之间传值
今天和朋友一块讨论,怎样通过js在父页面和子页面之间传值的问题,总结例如以下: 需求描写叙述:父页面有多个子页面.实如今父页面点击子页面,传值到子页面. 看着非常easy,试了好久.主要纠结在怎样获取 ...
- Iframe父页面与子页面之间的调用
原文:Iframe父页面与子页面之间的调用 Iframe父页面与子页面之间的调用 专业词语解释如下: Iframe:iframe元素是文档中的文档. window对象: 浏览器会在其打 ...
随机推荐
- 小米系列手机调试Installation failed with message Failed to establish session
用Android studio 2.3调度程序时提示"Installation failed with message Failed to establish session"错误 ...
- Dictionary and KeyValuePair关系
简单一句话: Dictionary 是 由 KeyValuePair结构 组成的集合 The Dictionary<TKey, TValue>.Enumerator.Current pro ...
- WebStorm中SVN配置
近期在使用WebStorm进行网页开发,值得一提的是WebStorm的确是一个不错的IDE,尽管可能内存开销较大,但是在编写JS的时候提供了很多包括自动完成等强大的功能. 好了,步入正题:在实际项目开 ...
- BZOJ 1680 [Usaco2005 Mar]Yogurt factory:贪心【只用考虑上一个】
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1680 题意: 在接下来的n周内,第i周生产一吨酸奶的成本为c[i],订单为y[i]吨酸奶. ...
- 利用Python+阿里云实现DDNS(动态域名解析)
引子我想大家应该都很熟悉DNS了,这回在DNS前面加了一个D又变成了什么呢?这个D就是Dynamic(动态),也就是说,按照传统,一个域名所对应的IP地址应该是定死的,而使用了DDNS后,域名所对应的 ...
- POJ 2503 Babelfish(map,字典树,快排+二分,hash)
题意:先构造一个词典,然后输入外文单词,输出相应的英语单词. 这道题有4种方法可以做: 1.map 2.字典树 3.快排+二分 4.hash表 参考博客:[解题报告]POJ_2503 字典树,MAP ...
- 分布式锁的实现方式——ACID数据库、缓存或者是zk
针对分布式锁的实现,目前比较常用的有以下几种方案: 基于数据库实现分布式锁 基于缓存(redis,memcached,tair)实现分布式锁 基于Zookeeper实现分布式锁 在分析这几种实现方案之 ...
- python做图笔记
1. 工具选择 了解了基本python,rodeo,anaconda套件这三种工具. (1)基本python,下载安装python的最新版(目前是python3.7).注意要使用安装版.安装好后,一般 ...
- mvc 让伪静态变得简单
IIS 部署后访问*.* config 配置: <modules runAllManagedModulesForAllRequests="true"> < ...
- PS 滤镜— —球面化效果
clc; clear all; close all; addpath('E:\PhotoShop Algortihm\Image Processing\PS Algorithm'); I=imread ...