温馨提示:本站仅提供公开网络链接索引服务,不存储、不篡改任何第三方内容,所有内容版权归原作者所有
AI智能索引来源:http://www.bun.com/reference/node/vm/runInThisContext
点击访问原文链接

Node vm.runInThisContext function | API Reference | Bun

Node vm.runInThisContext function | API Reference | BunBuildDocsReferenceGuidesBlogDiscord/node:vm/runInThisContextFrunInThisContext

Search the reference...

/

BuildDocsReferenceGuidesBlogDiscord/node:vm/runInThisContextFrunInThisContext

function

vm.runInThisContextfunction runInThisContext(code: string,options?: string | RunningCodeOptions): any;

vm.runInThisContext() compiles code, runs it within the context of the current global and returns the result. Running code does not have access to local scope, but does have access to the current global object.

If options is a string, then it specifies the filename.

The following example illustrates using both vm.runInThisContext() and the JavaScript eval() function to run the same code:

import { runInThisContext } from 'node:vm';
let localVar = 'initial value';

const vmResult = runInThisContext('localVar = "vm";');
console.log(`vmResult: '${vmResult}', localVar: '${localVar}'`);
// Prints: vmResult: 'vm', localVar: 'initial value'

const evalResult = eval('localVar = "eval";');
console.log(`evalResult: '${evalResult}', localVar: '${localVar}'`);
// Prints: evalResult: 'eval', localVar: 'eval'

Because vm.runInThisContext() does not have access to the local scope, localVar is unchanged. In contrast, eval() does have access to the local scope, so the value localVar is changed. In this way vm.runInThisContext() is much like an indirect eval() call, e.g.(0,eval)('code').

@param code

The JavaScript code to compile and run.

@returns

the result of the very last statement executed in the script.

Referenced typesinterface RunningCodeOptionsbreakOnSigint?: boolean

If true, the execution will be terminated when SIGINT (Ctrl+C) is received. Existing handlers for the event that have been attached via process.on('SIGINT') will be disabled during script execution, but will continue to work after that. If execution is terminated, an Error will be thrown.

cachedData?: ArrayBufferViewArrayBufferLike>

Provides an optional data with V8's code cache data for the supplied source.

columnOffset?: number

Specifies the column number offset that is displayed in stack traces produced by this script.

displayErrors?: boolean

When true, if an Error occurs while compiling the code, the line of code causing the error is attached to the stack trace.

filename?: string

Specifies the filename used in stack traces produced by this script.

importModuleDynamically?: number | DynamicModuleLoaderScript>

Used to specify how the modules should be loaded during the evaluation of this script when import() is called. This option is part of the experimental modules API. We do not recommend using it in a production environment. For detailed information, see Support of dynamic import() in compilation APIs.

lineOffset?: number

Specifies the line number offset that is displayed in stack traces produced by this script.

timeout?: number

Specifies the number of milliseconds to execute code before terminating execution. If execution is terminated, an Error will be thrown. This value must be a strictly positive integer.

Resources

ReferenceDocsGuidesDiscordMerch StoreGitHubBlog 

Toolkit

RuntimePackage managerTest runnerBundlerPackage runner

Project

Bun 1.0Bun 1.1Bun 1.2Bun 1.3RoadmapContributingLicense

Baked with ❤️ in San Francisco

We're hiring →

Node vm.runInThisContext function | API Reference | Bun,AI智能索引,全网链接索引,智能导航,网页索引

    API documentation for function node:vm.runInThisContext | Bun