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++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S