caoge c760052ff9 机车状态修改 | 8 mēneši atpakaļ | |
---|---|---|
.. | ||
.github | 8 mēneši atpakaļ | |
example | 8 mēneši atpakaļ | |
test | 8 mēneši atpakaļ | |
.travis.yml | 8 mēneši atpakaļ | |
CHANGELOG.md | 8 mēneši atpakaļ | |
LICENSE | 8 mēneši atpakaļ | |
index.js | 8 mēneši atpakaļ | |
package.json | 8 mēneši atpakaļ | |
readme.markdown | 8 mēneši atpakaļ | |
security.md | 8 mēneši atpakaļ |
emulate node's vm module for the browser
Just write some client-side javascript:
var vm = require('vm');
window.addEventListener('load', function () {
var res = vm.runInNewContext('a + 5', { a : 100 });
document.querySelector('#res').textContent = res;
});
compile it with browserify:
browserify entry.js -o bundle.js
then whip up some html:
<html>
<head>
<script src="/bundle.js"></script>
</head>
<body>
result = <span id="res"></span>
</body>
</html>
and when you load the page you should see:
result = 105
Evaluate some code
in a new iframe with a context
.
Contexts are like wrapping your code in a with()
except slightly less terrible
because the code is sandboxed into a new iframe.
This module is depended upon by browserify, so you should just be able to
require('vm')
and it will just work. However if you want to use this module
directly you can install it with npm:
npm install vm-browserify
MIT