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

相关文章

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法

《springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法》:本文主要介绍springboot整合阿里云百炼DeepSeek实现sse流式打印,本文给大家介绍的非常详细,对大... 目录1.开通阿里云百炼,获取到key2.新建SpringBoot项目3.工具类4.启动类5.测试类6.测

pytorch自动求梯度autograd的实现

《pytorch自动求梯度autograd的实现》autograd是一个自动微分引擎,它可以自动计算张量的梯度,本文主要介绍了pytorch自动求梯度autograd的实现,具有一定的参考价值,感兴趣... autograd是pytorch构建神经网络的核心。在 PyTorch 中,结合以下代码例子,当你

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各