首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过path.resolve(.)调用path.resolve.apply()的效果是什么?

通过path.resolve(.)调用path.resolve.apply()的效果是什么?
EN

Stack Overflow用户
提问于 2020-02-24 08:15:58
回答 1查看 90关注 0票数 0

在Azure管道任务库中,有一个通过apply()从打电话到path.resolve()的任务库,我并不真正理解它:

代码语言:javascript
复制
var absolutePath = path.resolve.apply(this, pathSegments);

其中pathSegments: any[]

上面的代码在一个在模块作用域导出的函数中,所以(如果我正确理解的话) this将引用模块本身。但是,我不知道通过apply调用的效果是什么,而不仅仅是直接调用path.resolve()。有人能解释吗?

上下文:我怀疑这可能与模仿有关--在等效的模拟模块中有一个相似函数,它使用path.posix.resolve.apply()。我的基本问题是,当我调用模拟的tl.resolve('') (通过tl.filePathSupplied()间接调用)时,它返回的是实际的cwd,而不是通过TaskLibAnswers被嘲笑的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-24 08:21:32

任何函数的.apply()方法都提供了两个特性:

  1. 它允许您在调用函数时设置this值。
  2. 它允许您传递任意参数数组,在调用函数时,这些参数将被解压缩为实际参数(而不是数组中的参数)。

在本例中,它可能是在这里使用的特性#2,因为path.resolve()接受任意数量的参数。如果您没有使用最新版本的node.js,或者不使用更低级别的Javascript支持,因此没有spread操作符,那么当参数在数组中传递给您时,.apply()将是将任意数量的参数传递给函数的自然方法。

如果查看模块并找到resolve()函数的代码,您将发现它根本不使用this值,因此path对象仅用作命名空间对象。因此,您可以将您想要的任何this值发送到解决函数中,这不会产生任何影响。

因此,很可能,代码使用.apply()并不是为了设置this的值,而是为了将任意的参数数组传递给函数。

但是,我不知道通过apply调用的效果是什么,而不仅仅是直接调用path.resolve()。有人能解释吗?

如果您向我们展示了更多的周围代码,我们可以更肯定地回答,但pathSegments变量似乎已经是这段代码希望传递给path.resolve()的路径值数组。如果这是一个任意数组,那么将该数组作为单独的参数传递给path.resolve()的两种最简单的方法是:

代码语言:javascript
复制
path.resolve.apply(path, pathSegments)

代码语言:javascript
复制
path.resolve(...pathSegments)

如果编写这段代码时考虑到了一个不具有...语法的旧目标,那么.apply()选项将是最简单的方法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60371799

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档