angularJS双向绑定和依赖反转

1、双向绑定:html

UI<-->数据app

数据->UI (数据改变UI跟着变)函数

UI->数据 (UI改变数据跟着变)双向绑定

 

数据改变->UI改变原理:htm

监听数据是否改变,若是改变动新UI数据。ip

 

UI改变->数据改变原理:get

<html>input

<body>string

<input type="text" name="name" value="" id="text1" ng_model="a">it

<script>

window.onload = function(){

var a='';

var oTxt = document.getElementById('text1');

oTxt.oninput = function(){  //UI值改变数据改变

a = oTxt.value;

}

}

</script>

</body>

</html>

 

 

2、依赖注入:

函数能够本身决定须要什么数据或者多小个数据,而不是外面传什么就用什么。

2.一、调用者决定给多小个参数

<script>

function show(a,b,c){

console.log(arguments.length);

}

show(1); //调用者只给1个参数,调用者决定参数的给予。

</script>


2.二、依赖注入(依赖反转):函数要求要多小参数,就给多小。 就像show(a,b,c)要求3个参数

<script>

function show(a,b,c){

console.log(arguments.length);

}

var scope = {a:12,b:15,c:99,qq:55,i:99};   //假设是函数须要的参数

//实现依赖反转二个步骤
//一、知道show要什么参数

var str = show.toString();

str=str.split('{')[0].match(/\(.*)\/)[0].replace(/\S+/g,'');

str=str.substring(1,str.length-1);

var arr=str.split(',');

//二、给它相应值

var args=[];

for(var i=0;i<arr.length;i++){

args[i]=scope[arr[i]];

}

console.log(args);

show.apply(null,args);

</script>

相关文章
相关标签/搜索