gpt4 book ai didi

javascript - JavaScript 中的重构模式

转载 作者:行者123 更新时间:2023-12-03 04:54:24 24 4
gpt4 key购买 nike

我正在编写一个小型应用程序,它与数据库进行通信,我没有使用回调模式,而是使用 Promises 来简化我的代码。完成大量编码后,我现在可以在代码中非常频繁地看到某些模式,我需要知道如何重构它,以便类似的逻辑位于单个位置。

  var queryString = "select * from users u inner join "+
"(select user_id, count(id) cnt from applications "+
"where id in (select id from applications where "+
"created_at > current_date - interval '1 week') "+
"group by user_id) a on u.id = a.user_id order by a.cnt desc";
var self = this;
return new Promise(function _promise(resolve, reject) {
req.client.query(queryString, [], function result(error, result) {
req.done(error);

if (error) {
console.log('error ' + error.message);
return reject(error);
}
var users = result.rows.map(function(row) {
return new User(row);
});
resolve(users);
});
});

上面的模式是我的每个方法,唯一不同的是 if 之后的内容,是否有任何功能方法可以用来重构它?

再添加一个示例:

  var queryString = 'select c.id, c.name, t.contact_user '+
'from companies c, teams t '+
'where t.user_id = $1::int and t.company_id = c.id '+
'limit $2::int';
var self = this;
return new Promise(function _promise(resolve, reject) {
req.client.query( queryString, [self.id, User._RESOURCE_LIMIT],
function result(error, result) {
req.done(error);
if (error) {
console.log('Error ' + error.message);
return reject(error);
}

self._companies = result.rows.map(function (data) {
return new Company(data);
});
resolve(self);
});
});

最佳答案

promise 的“查询”功能

let query = (req, queryString, arg = []) => new Promise((resolve, reject) => {
req.client.query(queryString, arg, (error, result) => {
req.done(error);
if (error) {
return reject(error);
}
resolve(result);
});
});

用法(按照问题中的示例)

query(req, "select * .... etc")
.then(result => {
return result.rows.map(function(row) {
return new User(row);
});
})
.catch(reason => {
// error handling goes here
});

关于javascript - JavaScript 中的重构模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42499807/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com