当将对象方法作为函数参数传递时,我必须使用`bind'来确保正确设置方法的上下文(this)。然后我的代码中有很多绑定......这是编写JS代码的简洁方法吗?传递方法的推荐设计模式是什么?也许我应该传递整个对象,或重新设计我的对象?
谢谢。
供您参考,我在此处粘贴了我的代码。这绝对不是一个好的代码。例如,我可能想要使用multi-sql-statements而不是逐个调用它们。
function insertDB(response, postData) {
var mysql = require('mysql');
var async = require('async');
var connection = mysql.createConnection({
host : 'localhost',
user : 'user',
password : 'pswd',
database : 'mydb',
});
async.series([
connection.connect.bind(connection),
async.apply(connection.query.bind(connection),
"CREATE TABLE IF NOT EXISTS concepts ("+
"name VARCHAR(64) NOT NULL,"+
"priority INT NOT NULL DEFAULT 0,"+
"date DATE NOT NULL,"+
"notes VARCHAR(256),"+
"PRIMARY KEY (name))"),
async.apply(connection.query.bind(connection),
"INSERT INTO concepts VALUES('" +
postData["word"] + "',0,CURDATE(),'')"),
connection.end.bind(connection)
],
function(err, result) {
if (err) console.error(err);
});
}
答案 0 :(得分:1)
您可以使用call或apply来执行此操作,两者都允许您设置范围并传递您想要的任何args。呼叫和应用之间的区别在于呼叫采用逗号分隔的争论,例如:
connection.connect.call( connection, arg1, arg2, arg2 );
并且应用了一系列这样的args:
var args = [ arg1, arg2, arg3 ];
connection.connect.apply( connection, args );