遇到一个需求, 在浏览器环境下来运行 js sdk 文件, 这个 js 文件是不能运行在 nodejs 环境下的; 所以通过 puppeteer 无头浏览器来运行代码获取对应的结果。
首先是安装插件 puppeteer,然后创建一个项目, 我这里是express;
这里是主要的代码。
const puppeteer = require('puppeteer');
const path = require('path')
const htmlPath = path.join(__dirname, './index.html');
function runCodeInBrowser() {
return new Promise(async (resolve, reject) => {
try {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto(`file://${htmlPath}`)
// 执行您自己的代码
const result = await page.evaluate(() => {
return test()
});
await browser.close();
resolve(result);
} catch (error) {
reject(error)
}
})
}
module.exports = runCodeInBrowser
代码解释:await page.goto(`file://${htmlPath}`)
这里是加载本地html文件, 在html文件里面导入你的js文件<script src="./test.js"></script>
, 然后就通过 page.evaluate(() => { return test() });
这个函数来获取你testjs文件里面的函数了; 需要注意的是, testjs文件里面的函数需要是全局变量;文章来源:https://www.toymoban.com/news/detail-726815.html
demo文章来源地址https://www.toymoban.com/news/detail-726815.html
到了这里,关于使用 puppeteer 加载 html 文件来运行 js 文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!