gpt4 book ai didi

javascript - 摆脱多余的方法定义

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

我用于构建路由的每个 HTTP 请求方法都有对应的四种方法。

每种方法的方案是:

RouteBuilder.prototype.>>METHOD<< = function (params, callback) {
if(typeof params === "function") {
callback = params;
router.>>METHOD<<(this._path, callback);
return;
}

var subRoute = params.subRoute || "";
var url = this._path + subRoute;
if(params.auth !== undefined) {
router.>>METHOD<<(url, Auth.authenticate(params.auth, { session: false }), callback);
} else {
router.>>METHOD<<(url, callback);
}
};

正如您可能怀疑的那样,这些方法的名称是:get、post、put 和delete。目前我有四个几乎相同的方法定义,我正在寻找更优雅的方法。

我考虑过创建一个包含方法名称的数组,并使用关键参数将方法映射到它,但在循环中创建函数似乎不是一个好主意。我还需要这些方法与 JSDoc 兼容。

最佳答案

好吧,我会发布一个答案,因为你已经完成了 99% 的工作。您在问题中发布的代码非常接近您正在寻找的通用解决方案:

RouteBuilder.prototype.route = function (method, params, callback) {
if(typeof params === "function") {
callback = params;
router[method](this._path, callback);
return;
}

var subRoute = params.subRoute || "";
var url = this._path + subRoute;
if(params.auth !== undefined) {
router[method](url, Auth.authenticate(params.auth, { session: false }), callback);
} else {
router[method](url, callback);
}
};

RouteBuilder.prototype.get = function(params, callback) {
this.route("get", params, callback);
};

RouteBuilder.prototype.put = function(params, callback) {
this.route("put", params, callback);
};

RouteBuilder.prototype.post = function(params, callback) {
this.route("post", params, callback);
};

RouteBuilder.prototype.del = function(params, callback) {
this.route("del", params, callback);
};

关于javascript - 摆脱多余的方法定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29169055/

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