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

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解