Maison > Questions et réponses > le corps du texte
<!doctype html>
<html lang="zh-CN">
<head>
<meta http-equiv="X-UA-Compatible" content="IE=edge"/>
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
<meta charset="UTF-8"/>
<title>Document</title>
</head>
<body>
<script>
var test=(function(a){
this.a=a;
return function(b){
return this.a+b;
}
}(function(a,b){
return a;
debugger;
}(1,2)));
console.log(test(4))
//结果是输出5 求解?
</script>
</body>
</html>
女神的闺蜜爱上我2017-07-07 10:36:36
Mémoire
let functionA = function (a) {
this.a = a
return function (b) {
return this.a + b
}
}
let argA = function (a, b) {
return a
debugger
}(1, 2)
// 实际上 argA 就等于 1,** 这个地方的 b 没有被用到 **
La formule originale est simplifiée en :
let test = functionA(argA)
Une fois cette phrase exécutée, test
est en fait
function (b) {
return this.a + b
}
// ** 这是一个带一个参数的函数,执行 test(4) 时 b 就是 4 **
Et en ce moment this.a
等于 1
。因此 test(4)
结果为 5
黄舟2017-07-07 10:36:36
Il est évidemment 5 heures
var test = function(a){
this.a = a;
return function(b){
return this.a + b;
}
}(function(a,b){
return a;
}(1,2))
Répartition
var test = function(a){
this.a = a;
return function(b){
return this.a + b;
}
}
var getA = function(a,b){
return a;
}
test(getA(1,2))(4);
Si vous ne comprenez toujours pas cela, vous devez apprendre les bases
typecho2017-07-07 10:36:36
Nous devons d'abord comprendre que la variable test est en fait une fonction, comme suit
.var test = function(b){
return this.a + b;
}
La partie extérieure est une fonction qui est exécutée immédiatement. Premièrement,
.function(a,b){
return a;
}(1,2)
Le résultat de cette partie est 1, c'est-à-dire que le code peut être simplifié à :
var test=(function(a){
this.a=a;
return function(b){
return this.a+b;
}
}(1));
Dans le code ci-dessus, a=1
, donc dans test(4), on obtient :
var test=(function(a){ // a = 1
this.a=a;
return function(b){ // b = 4
return this.a+b; // 得到 1 + 4
}
}(1));