var array_of_functions = [
first_function('a string'),
second_function('a string'),
third_function('a string'),
forth_function('a string')
]
array_of_functions[0];
配列が作成されると、配列内の各関数が実行されるため、意図したとおりに機能しません。
配列内の関数を実行する適切な方法は何ですか:
array_of_functions[0]; // or, array_of_functions[1] etc.
ありがとう!
var array_of_functions = [
first_function,
second_function,
third_function,
forth_function
]
そして、配列内の特定の関数を実行する場合:
array_of_functions[0]('a string');
私はこれが元のポスターが達成することを意味していたと思います:
var array_of_functions = [
function() { first_function('a string') },
function() { second_function('a string') },
function() { third_function('a string') },
function() { fourth_function('a string') }
]
for (i = 0; i < array_of_functions.length; i++) {
array_of_functions[i]();
}
うまくいけば、これが他の人(20分前の私のように:-)を助けて、配列でJS関数を呼び出す方法についてのヒントを探します。
あなたが達成しようとしていることの詳細なしで、私たちはちょっと推測しています。しかし、あなたはこのようなことをするためにオブジェクト表記を使用して逃げることができるかもしれません...
var myFuncs = {
firstFunc: function(string) {
// do something
},
secondFunc: function(string) {
// do something
},
thirdFunc: function(string) {
// do something
}
}
そしてそれらの1つを呼び出すために...
myFuncs.firstFunc('a string')
あるいは単に:
var myFuncs = {
firstFun: function(string) {
// do something
},
secondFunc: function(string) {
// do something
},
thirdFunc: function(string) {
// do something
}
}
shift()
Javascriptメソッドを使用して配列内のさまざまな関数を実行する簡単な方法を投稿することで、このスレッドを補完します 元々ここで説明しました
var a = function(){ console.log("this is function: a") }
var b = function(){ console.log("this is function: b") }
var c = function(){ console.log("this is function: c") }
var foo = [a,b,c];
while (foo.length){
foo.shift().call();
}
基本的にDarin Dimitrov's
と同じですが、関数と引数を動的に作成および保存する方法を示しています。私はそれがあなたに役立つことを願っています:)
var argsContainer = ['hello', 'you', 'there'];
var functionsContainer = [];
for (var i = 0; i < argsContainer.length; i++) {
var currentArg = argsContainer[i];
functionsContainer.Push(function(currentArg){
console.log(currentArg);
});
};
for (var i = 0; i < functionsContainer.length; i++) {
functionsContainer[i](argsContainer[i]);
}
上に繰り返しのあるものを見ました。 forEachを使用して同じことをしましょう。
var funcs = [function () {
console.log(1)
},
function () {
console.log(2)
}
];
funcs.forEach(function (func) {
func(); // outputs 1, then 2
});
//for (i = 0; i < funcs.length; i++) funcs[i]();
ES6コールバックを介した多くの機能の実行????
const f = (funs) => {
funs().forEach((fun) => fun)
}
f(() => [
console.log(1),
console.log(2),
console.log(3)
])
動的にコールバックを渡そうとするようなことをしているなら、引数として単一のオブジェクトを渡すことができます。これにより、どのパラメーターを使用して実行する関数をより詳細に制御できます。
function func_one(arg) {
console.log(arg)
};
function func_two(arg) {
console.log(arg+' make this different')
};
var obj = {
callbacks: [func_one, func_two],
params: ["something", "something else"];
};
function doSomething(obj) {
var n = obj.counter
for (n; n < (obj.callbacks.length - obj.len); n++) {
obj.callbacks[n](obj.params[n]);
}
};
obj.counter = 0;
obj.len = 0;
doSomething(obj);
//something
//something else make this different
obj.counter = 1;
obj.len = 0;
doSomething(obj);
//something else make this different
これは正しいです
var array_of_functions = {
"all": function(flag) {
console.log(1+flag);
},
"cic": function(flag) {
console.log(13+flag);
}
};
array_of_functions.all(27);
array_of_functions.cic(7);
これらの関数の配列の問題は「配列形式」ではなく、これらの関数が呼び出される方法で...そして...これを試してみてください..簡単なeval()...
array_of_function = ["fx1()","fx2()","fx3()",.."fxN()"]
var zzz=[];
for (var i=0; i<array_of_function.length; i++)
{ var zzz += eval( array_of_function[i] ); }
それはここにあります。アッパーは家で仕事をしていませんでした...助けになることを願っています
すべてを実行する簡単な方法:
[first_function, ..., nth_function].forEach (function(f) {
f('a string');
});
Function.prototype.bind()を使用する
var array_of_functions = [
first_function.bind(null,'a string'),
second_function.bind(null,'a string'),
third_function.bind(null,'a string'),
forth_function.bind(null,'a string')
]
私はこれを解決しようとして多くの問題を抱えています...明白なことを試みましたが、うまくいきませんでした。何とか空の関数を追加するだけです。
array_of_functions.Push(function() { first_function('a string') });
文字列の配列を使用し、後でevalを使用して解決しました。
array_of_functions.Push("first_function('a string')");
for (var Func of array_of_functions) {
eval(Func);
}
たぶんそれは誰かを助けることができます。
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
window.manager = {
curHandler: 0,
handlers : []
};
manager.run = function (n) {
this.handlers[this.curHandler](n);
};
manager.changeHandler = function (n) {
if (n >= this.handlers.length || n < 0) {
throw new Error('n must be from 0 to ' + (this.handlers.length - 1), n);
}
this.curHandler = n;
};
var a = function (n) {
console.log("Handler a. Argument value is " + n);
};
var b = function (n) {
console.log("Handler b. Argument value is " + n);
};
var c = function foo(n) {
for (var i=0; i<n; i++) {
console.log(i);
}
};
manager.handlers.Push(a);
manager.handlers.Push(b);
manager.handlers.Push(c);
</script>
</head>
<body>
<input type="button" onclick="window.manager.run(2)" value="Run handler with parameter 2">
<input type="button" onclick="window.manager.run(4)" value="Run handler with parameter 4">
<p>
<div>
<select name="featured" size="1" id="item1">
<option value="0">First handler</option>
<option value="1">Second handler</option>
<option value="2">Third handler</option>
</select>
<input type="button" onclick="manager.changeHandler(document.getElementById('item1').value);" value="Change handler">
</div>
</p>
</body>
</html>