vconsole助力实现在线代码编辑调试

2024-04-05 03:12

本文主要是介绍vconsole助力实现在线代码编辑调试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

前面有文章monaco-editor做自己的代码测试工具 ,本文书接前文,在代码中加入vconsole工具,可以进行代码调试、查看网络、查看元素等。

效果

demo.png

vconsole简介

vconsole是一个轻量、可拓展、针对手机网页的前端开发者调试面板。跟框架无关的,可以在 Vue、React 或其他任何框架中使用。具有如下功能特性:

  • 日志(Logs): console.log|info|error|…
  • 网络(Network): XMLHttpRequest, Fetch, sendBeacon
  • 节点(Element): HTML 节点树
  • 存储(Storage): Cookies, LocalStorage, SessionStorage
  • 手动执行 JS 命令行
  • 自定义插件

实现

1. 编辑器组件

编辑器的实现前面的文章有介绍过,本文在此基础上做了优化,实现代码如下:

<template><div class="editor-title">{{ editorTitle }}</div><div class="editor-content" :id="`${language}Editor`"></div>
</template><script>
import * as monaco from "monaco-editor";
import editorWorker from 'monaco-editor/esm/vs/editor/editor.worker?worker';
import jsonWorker from 'monaco-editor/esm/vs/language/json/json.worker?worker';
import cssWorker from 'monaco-editor/esm/vs/language/css/css.worker?worker';
import htmlWorker from 'monaco-editor/esm/vs/language/html/html.worker?worker';
import tsWorker from 'monaco-editor/esm/vs/language/typescript/ts.worker?worker';self.MonacoEnvironment = {getWorker(_, label) {if (label === 'json') {return new jsonWorker();}if (label === 'css' || label === 'scss' || label === 'less') {return new cssWorker();}if (label === 'html' || label === 'handlebars' || label === 'razor') {return new htmlWorker();}if (label === 'typescript' || label === 'javascript') {return new tsWorker();}return new editorWorker();},
};let editorInstance = {}export default {computed: {editorTitle() {return this.title || this.language}},mounted() {this.initEditor()},props: {title: {type: String,default: ''},language: {type: String,default: ''},value: {type: String,default: ''}},methods: {initEditor() {const dom = document.getElementById(`${this.language}Editor`)editorInstance[this.language] = monaco.editor.create(dom, {value: this.value,theme: "vs-dark",language: this.language,fontSize: 14});},getCode() {return editorInstance[this.language]?.getValue() || ''},}
}
</script><style scoped lang="scss">
$height: 2rem;.editor-title {height: $height;line-height: $height;background-color: #003f8f;color: #fff;padding: 0 0.5rem;font-size: 1rem;font-weight: bold;
}.editor-content {height: calc(100% - #{$height});width: 100%;
}
</style>

注意:在实现编辑器组件的时候,发现在data中定义编辑器实例在调用getValue()的时候会出现卡死的现象,但是如果定义一个变量的话,获取到的值是最后一个编辑器的值。

2. 引用组件,实现

代码的运行预览通过iframe实现,引用组件实现的完整代码如下:

<template><div class="editor-content"><button class="tools-button" @click="runCode">运行</button><div class="editor"><Editor language="html" ref="htmlEditor"></Editor></div><div class="editor"><Editor language="css" ref="cssEditor"></Editor></div><div class="editor"><Editor language="javascript" ref="jsEditor"></Editor></div></div><iframe id="preview" frameborder="0" class="preview-content"></iframe>
</template><script>
import Editor from './components/Editor.vue'export default {components: {Editor},mounted() {this.runCode()},methods: {runCode() {const htmlCode = this.$refs.htmlEditor.getCode()const cssCode = this.$refs.cssEditor.getCode()const jsCode = this.$refs.jsEditor.getCode()const srcdoc = `<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>html,body {height: 100%;margin: 0;padding: 0;}.container {height: calc(100% - 15rem);}.console {height: 15rem;}.vc-mask {display: none !important;}.vc-panel {left: auto;bottom: auto !important;height: 100%;width: 100%;}${cssCode}</style><script src="https://unpkg.com/vconsole@latest/dist/vconsole.min.js"><\/script></head><body><div class="container">${htmlCode}</div><div class="console" id="console"></div><script>// 创建调试器const target = document.getElementById('console')const vConsole = new window.VConsole({defaultPlugins: ['network', 'element', 'storage'],target});setTimeout(() => {vConsole.hideSwitch();vConsole.show()}, 100) ${jsCode}<\/script></body></html>`console.log({htmlCode,cssCode,jsCode})const preview = document.getElementById('preview')preview.setAttribute("srcdoc", srcdoc);}}
}
</script><style lang="scss">
.editor-content, .preview-content {height: 100%;width: 50%;float: left;position: relative;.editor {height: calc(100% / 3)}.tools-button {position: absolute;right: 5px;top: 3px;z-index: 100;}
}
</style>

参考引用

  • monaco-editor做自己的代码测试工具 (文章地址:http://t.csdnimg.cn/R0Qyo)

这篇关于vconsole助力实现在线代码编辑调试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/877506

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo