首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >有没有办法将所有控制台输出记录到HTML页面?

有没有办法将所有控制台输出记录到HTML页面?
EN

Stack Overflow用户
提问于 2021-03-31 12:35:52
回答 1查看 47关注 0票数 0

我正在开发一个电子应用程序来运行我的discord.js机器人,我想要将任何可能抛到控制台的错误记录到我创建的div的html中。我把它用在console.logconsole.error上,但discord.js用的是throw new Error。有没有办法从这些类型的错误中提取错误内容,以便将其打印到我的新“控制台”中?

下面是我做console.log的方法:

代码语言:javascript
复制
console.log = function(message) {
    document.getElementById('console-text').innerHTML += `<p class="console-output">${message}<p>`
  };
EN

回答 1

Stack Overflow用户

发布于 2021-03-31 12:38:34

您可以将error侦听器添加到窗口中:

代码语言:javascript
复制
const container = document.getElementById('console-text');
window.addEventListener('error', (error) => {
  const p = container.appendChild(document.createElement('p'));
  p.textContent = error.message;
  p.className = 'console-output';
});

throw new Error('foobar');
代码语言:javascript
复制
<div id="console-text"></div>

在Node中,可以通过侦听unhandledException事件来完成相同的操作:

代码语言:javascript
复制
require('process').on('uncaughtException', (error) => {

我建议不要做

代码语言:javascript
复制
.innerHTML += `<p class="console-output">${message}<p>`

因为这允许执行任意代码。显式创建<p>元素并将其分配给它的textContent

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

https://stackoverflow.com/questions/66881714

复制
相关文章

相似问题

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