JS在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,更高效的运行,点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
nodejs function 发布于:2022-09-28 10:52 Promise 高级考核;不计原理,计原理产生的效果;原理太懵逼; 发布于:2022-09-24 20:23 测试 grok-js 发布于:2022-09-23 15:14 获取案件服务人员分支机构、部门信息 发布于:2022-09-22 14:06 将平行结构数据转为树形结构 发布于:2022-09-22 09:19 js 获取 url 的某个参数 发布于:2022-09-21 16:26 股票报价js 发布于:2022-09-20 18:05 JS call()方法 发布于:2022-09-20 14:46 JS 深拷贝 发布于:2022-09-20 14:26 测试Vue-Quill-Editor 发布于:2022-09-20 14:11 员工排序js版 发布于:2022-09-19 16:09 给你一个字符串 s,请你返回 两个相同字符之间的最长子字符串的长度 ,计算长度时不含这两个字符。如果不存在这样的子字符串,返回 -1 。 子字符串 是字符串中的一个连续字符序列。 发布于:2022-09-28 11:16 看代码说出运行结果 发布于:2022-09-17 09:48 哔哩哔哩密码逆向 发布于:2022-09-16 21:16 临时数据处理 发布于:2022-09-16 16:18 实现一个插入排序 发布于:2022-09-16 00:16 手动实现一个Array的sort 发布于:2022-09-16 00:01 给你一个整数数组 arr ,请你删除最小 5% 的数字和最大 5% 的数字后,剩余数字的平均值。 与 标准答案 误差在 10-5 的结果都被视为正确结果。 发布于:2022-09-15 17:14 // 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数, // 并返回它们的数组下标。 发布于:2022-09-15 17:01 实现一个控制并发的Scheduler调度器 addTask(1000,"1"); addTask(500,"2"); addTask(300,"3"); addTask(400,"4"); 的输出顺序是:2 3 1 4 整个的完整执行流程: 一开始1、2两个任务开始执行 500ms时,2任务执行完毕,输出2,任务3开始执行 800ms时,3任务执行完毕,输出3,任务4开始执行 1000ms时,1任务执行完毕,输出1,此时只剩下4任务在执行 1200ms时,4任务执行完毕,输出4 发布于:2022-09-15 16:50 测试一些JS知识点 发布于:2022-09-15 13:36 trans(123456) —— 十二万三千四百五十六 trans(100010001)—— 一亿零一万零一 发布于:2022-09-15 16:15 根据项目业务需求,进行以下两种格式的互相转换 例如 let arr=[1,2,3,4,5] let arr2=null let arr3 = ['a','b'] format_data({q:arr,w:arr2,e:arr3}) [ { q: 1, w: null, e: 'a' }, { q: 2, w: null, e: 'b' }, { q: 3, w: null, e: null }, { q: 4, w: null, e: null }, { q: 5, w: null, e: null } ] 发布于:2022-09-14 14:36 防抖和节流 发布于:2022-09-13 11:06 递归实现斐波那契数列 发布于:2022-09-12 17:41 反直觉 数组操作 发布于:2022-09-11 11:21 数组所有组合的算法 发布于:2022-09-11 10:01 复选框全选与取消 发布于:2022-09-09 23:43 让对象按数组迭代 发布于:2022-09-09 16:54 使用JS实现一个单链表的类 发布于:2022-09-09 15:44 找出字符串中出现次数最多的字符及次数 发布于:2022-09-09 12:03 字符串中a出现的位置及次数 发布于:2022-09-09 11:46 js数组去重 发布于:2022-09-09 11:29 斐波那契数列 // F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2) 斐波那契数列的memoization优化 发布于:2022-09-14 17:23 扁平数组转tree 发布于:2022-09-08 15:29 扁平数据转为tree(只能处理一层) 发布于:2022-09-08 14:56 封装localStorage 发布于:2022-09-08 14:46 jq.on原理实现 发布于:2022-09-07 00:42 实现一个对象拍平 发布于:2022-09-06 00:27 使用proxy实现一个对象属性的双向绑定 发布于:2022-09-05 17:17 遍历一次将扁平数据转为tree 发布于:2022-09-05 19:02 this指向,手写bind、call、apply、new 发布于:2022-09-04 21:07 字符串是有括号组成,判断内容是否为有效内容 发布于:2022-09-04 00:29 自己实现一个new 发布于:2022-09-03 17:09 使用renduce实现一个map、filter 发布于:2022-09-03 12:06 Js 使用reduce实现一个map 发布于:2022-09-02 00:12 JS实现一个观察者模式 发布于:2022-09-02 00:07 学习倾国每日答题多选题 发布于:2022-09-01 18:29 加密工具箱 发布于:2022-09-01 17:00 一大堆数里面找到一个和数值A最接近的数 发布于:2022-09-01 15:14 [更多]
显示目录

虚拟机



虚拟机

稳定性: 3 - 稳定

本节介绍了Node.js的虚拟机(VM)模块,该模块提供了用于在V8虚拟机上下文中编译和运行代码的API。

可以通过以下方法访问该模块:

var vm = require('vm');

JavaScript 可以立即编译立即执行,也可以编译,保存,之后再运行。

vm.runInThisContext(code[, options])

vm.runInThisContext()对参数code编译,运行并返回结果。运行的代码没有权限访问本地作用域(local scope),但是可以访问全局对象。

使用vm.runInThisContexteval方法运行同样代码的例子:

var localVar = 'initial value';

var vmResult = vm.runInThisContext('localVar = "vm";');
console.log('vmResult: ', vmResult);
console.log('localVar: ', localVar);

var evalResult = eval('localVar = "eval";');
console.log('evalResult: ', evalResult);
console.log('localVar: ', localVar);

// vmResult: 'vm', localVar: 'initial value'
// evalResult: 'eval', localVar: 'eval'

vm.runInThisContext没有访问本地作用域,所以没有改变localVareval范围了本地作用域,所以改变了localVar

vm.runInThisContext用起来很像间接调用eval,比如(0,eval)('code')。但是,vm.runInThisContext也包含以下选项:

  • filename: 允许更改显示在站追踪(stack traces)的文件名。
  • displayErrors: 是否在stderr上打印错误,抛出异常的代码行高亮显示。会捕获编译时的语法错误,和执行时抛出的错误。默认为true
  • timeout: 中断前代码执行的毫秒数。如果执行终止,将会抛出错误。

vm.createContext([sandbox])

如果参数sandbox不为空,调用vm.runInContextscript.runInContext时可以调用沙箱的上下文。以此方式运行的脚本,sandbox是全局对象,它保留自己的属性同时拥有标准全局对象(global object)拥有的内置对象和函数。

如果参数sandbox对象为空,返回一个可用的新且空的上下文相关的沙盒对象。

这个函数对于创建一个可运行多脚本的沙盒非常有用。比如,在模拟浏览器的时候可以使用该函数创建一个用于表示window全局对象的沙箱,并将所有<script>标签放入沙箱执行。

vm.isContext(sandbox)

沙箱对象是否已经通过调用vm.createContext上下文化。

vm.runInContext(code, contextifiedSandbox[, options])

vm.runInContext编译代码,运行在contextifiedSandbox并返回结果。运行代码不能访问本地域。contextifiedSandbox对象必须通过 vm.createContext上下文化;code 会通过全局变量使用它。

vm.runInContextvm.runInThisContext参数相同。

在同一个上下文中编译并执行不同的脚本,例子:

var util = require('util');
var vm = require('vm');

var sandbox = { globalVar: 1 };
vm.createContext(sandbox);

for (var i = 0; i < 10; ++i) {
    vm.runInContext('globalVar *= 2;', sandbox);
}
console.log(util.inspect(sandbox));

// { globalVar: 1024 }

注意,执行不被信任的代码是需要技巧且要非常的小心。vm.runInContext非常有用,不过想要安全些,最好还是在独立的进程里运行不被信任的代码。

vm.runInNewContext(code[, sandbox][, options])

vm.runInNewContext编译代码, 如果提供了sandbox ,则将sandbox上下文化,否则创建一个新的上下文化过的沙盒,将沙盒作为全局变量运行代码并返回结果。

vm.runInNewContextvm.runInThisContext参数相同。

编译并执行代码,增加全局变量值,并设置一个新的。这些全局变量包含在一个新的沙盒里。

var util = require('util');
var vm = require('vm'),

var sandbox = {
  animal: 'cat',
  count: 2
};

vm.runInNewContext('count += 1; name = "kitty"', sandbox);
console.log(util.inspect(sandbox));

// { animal: 'cat', count: 3, name: 'kitty' }

注意,执行不被信任的代码是需要技巧且要非常的小心。vm.runInNewContext非常有用,不过想要安全些,最好还是在独立的进程里运行不被信任的代码。

vm.runInDebugContext(code)

vm.runInDebugContext在V8的调试上下文中编译并执行。最主要的应用场景是获得V8调试对象访问权限。

var Debug = vm.runInDebugContext('Debug');
Debug.scripts().forEach(function(script) { console.log(script.name); });

注意,调试上下文和对象内部绑定到V8的调试实现里,并可能在没有警告时改变(或移除)。

可以通过--expose_debug_as=开关暴露调试对象。

Class: Script

包含预编译脚本的类,并在指定的沙盒里执行。

new vm.Script(code, options)

创建一个新的脚本编译代码,但是不运行。使用被创建的vm.Script来表示编译完的代码。这个代码可以使用以下的方法调用多次。返回的脚本没有绑定到任何全局变量。在运行前绑定,执行后释放。

创建脚本的选项有:

  • filename: 允许更改显示在站追踪(stack traces)的文件名。
  • displayErrors: 是否在stderr上打印错误,抛出异常的代码行高亮显示。只会捕获编译时的语法错误,执行时抛出的错误由脚本的方法的选项来控制。默认为 true

script.runInThisContext([options])

vm.runInThisContext类似,只是作为Script脚本对象的预编译方法。script.runInThisContext执行编译过的脚本并返回结果。被运行的代码没有本地作用域访问权限,但是拥有权限访问全局对象。

以下例子,使用script.runInThisContext编译代码一次,并运行多次:

var vm = require('vm');

global.globalVar = 0;

var script = new vm.Script('globalVar += 1', { filename: 'myfile.vm' });

for (var i = 0; i < 1000; ++i) {
  script.runInThisContext();
}

console.log(globalVar);

// 1000

所运行的代码选项:

  • displayErrors: 是否在stderr上打印错误,抛出异常的代码行高亮显示。仅适用于执行时抛出的错误。不能创建一个语法错误的Script实例,因为构造函数会抛出。
  • timeout: 中断前代码执行的毫秒数。如果执行终止,将会抛出错误。

script.runInContext(contextifiedSandbox[, options])

vm.runInContext类似,只是作为预编译的Script对象方法。script.runInContext运行脚本(在contextifiedSandbox中编译)并返回结果。运行的代码没有权限访问本地域。

script.runInContext的选项和script.runInThisContext类似。

例子:编译一段代码,并执行多次,这段代码实现了一个全局变量的自增,并创建一个新的全局变量。这些全局变量保存在沙盒里。

var util = require('util');
var vm = require('vm');

var sandbox = {
  animal: 'cat',
  count: 2
};

var script = new vm.Script('count += 1; name = "kitty"');

for (var i = 0; i < 10; ++i) {
  script.runInContext(sandbox);
}

console.log(util.inspect(sandbox));

// { animal: 'cat', count: 12, name: 'kitty' }

注意,执行不被信任的代码是需要技巧且要非常的小心。script.runInContext非常有用,不过想要安全些,最好还是在独立的进程里运行不被信任的代码。

script.runInNewContext([sandbox][, options])

vm.runInNewContext类似,只是作为预编译的Script对象方法。若提供sandbox则script.runInNewContext将sandbox上下文化,若未提供,则创建一个新的上下文化的沙箱。

script.runInNewContextscript.runInThisContext的参数类似。

例子:编译代码(设置了一个全局变量)并在不同的上下文里执行多次。这些全局变量会被保存在沙箱中。

var util = require('util');
var vm = require('vm');

var sandboxes = [{}, {}, {}];

var script = new vm.Script('globalVar = "set"');

sandboxes.forEach(function (sandbox) {
  script.runInNewContext(sandbox);
});

console.log(util.inspect(sandboxes));

// [{ globalVar: 'set' }, { globalVar: 'set' }, { globalVar: 'set' }]

注意,执行不被信任的代码是需要技巧且要非常的小心。script.runInNewContext非常有用,不过想要安全些,最好还是在独立的进程里运行不被信任的代码。

由JSRUN为你提供的JS在线运行、在线编译工具
        JSRUN提供的JS在线运行,JS 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿

  • 00:23
注册登录后可减少验证码的弹出,点击前往 注册 | 登录

皮肤:

运行模式:

嵌入代码 iframe嵌入:


服务器已安装大部分常用的第依赖库,但仍可能存在一些未被安装的库, 可以通过本窗口立即安装所需依赖库。


请输入依赖库的名称:

请选择语言: