vue3+ts 使用vue3-ace-editor实现Json编辑器

1、效果图

输入代码,点击格式化就出现以上效果,再点击压缩,是以下效果
2、安装

复制代码
npm i vue3-ace-editor

3、使用

新建aceConfig.js文件

复制代码
// ace配置,使用动态加载来避免第一次加载开销
import ace from 'ace-builds'

// 导入不同的主题模块,并设置对应 URL
import themeGithubUrl from 'ace-builds/src-noconflict/theme-github?url'
ace.config.setModuleUrl('ace/theme/github', themeGithubUrl)

import themeChromeUrl from 'ace-builds/src-noconflict/theme-chrome?url'
ace.config.setModuleUrl('ace/theme/chrome', themeChromeUrl)

import themeMonokaiUrl from 'ace-builds/src-noconflict/theme-monokai?url'
ace.config.setModuleUrl('ace/theme/monokai', themeMonokaiUrl)

// 导入不同语言的语法模式模块,并设置对应 URL (所有支持的主题和模式:node_modules/ace-builds/src-noconflict)
import modeJsonUrl from 'ace-builds/src-noconflict/mode-json?url'
ace.config.setModuleUrl('ace/mode/json', modeJsonUrl)

import modeJavascriptUrl from 'ace-builds/src-noconflict/mode-javascript?url'
ace.config.setModuleUrl('ace/mode/javascript', modeJavascriptUrl)

import modeHtmlUrl from 'ace-builds/src-noconflict/mode-html?url'
ace.config.setModuleUrl('ace/mode/html', modeHtmlUrl)

import modePythonUrl from 'ace-builds/src-noconflict/mode-python?url'
ace.config.setModuleUrl('ace/mode/yaml', modePythonUrl)

// 用于完成语法检查、代码提示、自动补全等代码编辑功能,必须注册模块 ace/mode/lang _ worker,并设置选项 useWorker: true
import workerBaseUrl from 'ace-builds/src-noconflict/worker-base?url'
ace.config.setModuleUrl('ace/mode/base', workerBaseUrl)

import workerJsonUrl from 'ace-builds/src-noconflict/worker-json?url' // for vite
ace.config.setModuleUrl('ace/mode/json_worker', workerJsonUrl)

import workerJavascriptUrl from 'ace-builds/src-noconflict/worker-javascript?url'
ace.config.setModuleUrl('ace/mode/javascript_worker', workerJavascriptUrl)

import workerHtmlUrl from 'ace-builds/src-noconflict/worker-html?url'
ace.config.setModuleUrl('ace/mode/html_worker', workerHtmlUrl)

// 导入不同语言的代码片段,提供代码自动补全和代码块功能
import snippetsJsonUrl from 'ace-builds/src-noconflict/snippets/json?url'
ace.config.setModuleUrl('ace/snippets/json', snippetsJsonUrl)

import snippetsJsUrl from 'ace-builds/src-noconflict/snippets/javascript?url'
ace.config.setModuleUrl('ace/snippets/javascript', snippetsJsUrl)

import snippetsHtmlUrl from 'ace-builds/src-noconflict/snippets/html?url'
ace.config.setModuleUrl('ace/snippets/html', snippetsHtmlUrl)

import snippetsPyhontUrl from 'ace-builds/src-noconflict/snippets/python?url'
ace.config.setModuleUrl('ace/snippets/javascript', snippetsPyhontUrl)

// 启用自动补全等高级编辑支持,
import extSearchboxUrl from 'ace-builds/src-noconflict/ext-searchbox?url'
ace.config.setModuleUrl('ace/ext/searchbox', extSearchboxUrl)

// 启用自动补全等高级编辑支持
import 'ace-builds/src-noconflict/ext-language_tools'
ace.require('ace/ext/language_tools')

4、在页面使用

复制代码
<template>
  <div>
    <div class="flex justify-between mb-2">
      <el-tag color="#eff0ff" effect="light">json</el-tag>
      <div>
        <el-button color="#8769db" size="small" @click="jsonFormat">{{ $t('format') }}</el-button>
        <el-button size="small" @click="jsonNoFormat">{{ $t('zip') }}</el-button>
      </div>
    </div>
    <v-ace-editor
      v-model:value="content"
      lang="json"
      theme="chrome"
      :options="options"
      class="w-full text-base pt-5"
      :readonly="options.readOnly"
    />
  </div>
</template>

<script lang="ts" setup>
import { ref, reactive, watch } from 'vue'
import emitter from '@/utils/emitter'
import { VAceEditor } from 'vue3-ace-editor'
import './aceConfig.js'

const content = ref('') // 显示的内容

const options = reactive({
  useWorker: true, // 启用语法检查,必须为true
  enableBasicAutocompletion: true, // 自动补全
  enableLiveAutocompletion: true, // 智能补全
  enableSnippets: true, // 启用代码段
  showPrintMargin: false, // 去掉灰色的线,printMarginColumn
  highlightActiveLine: false, // 高亮行
  highlightSelectedWord: true, // 高亮选中的字符
  tabSize: 4, // tab锁进字符
  fontSize: 14, // 设置字号
  wrap: false, // 是否换行
  readOnly: false, // 是否可编辑
  minLines: 1, // 最小行数,minLines和maxLines同时设置之后,可以不用给editor再设置高度
  maxLines: 50, // 最大行数
})

// JSON格式化
const jsonFormat = () => {
  try {
    content.value = JSON.stringify(JSON.parse(content.value), null, 2)
  } catch (e) {
    jsonError(e)
  }
}

// JSON压缩
const jsonNoFormat = () => {
  try {
    content.value = JSON.stringify(JSON.parse(content.value))
  } catch (e) {
    jsonError(e)
  }
}

watch(
  () => content.value,
  (newContent) => {
    emitter.emit('handleCondition', newContent)
  },
  { deep: true, immediate: true },
)

const jsonError = (e: any) => {
  console.log(`JSON字符串错误:${e.message}`)
}
</script>

<style>
.ace_gutter {
  background-color: transparent !important;
}
.ace-chrome .ace_gutter-active-line {
  background-color: transparent !important;
}
</style>

参考:vue3-ace-editor使用记录-CSDN博客

相关推荐
codingandsleeping2 分钟前
pnpm + monorepo:高效的项目管理方式
前端
姜太小白10 分钟前
【VSCode】VS Code自动换行设置方法
ide·vscode·编辑器
程序员三千_19 分钟前
最近爆火的MCP到底是什么?
前端
古时的风筝32 分钟前
暴论:2025年,程序员必学技能就是MCP
前端·后端·mcp
古时的风筝32 分钟前
这编程圈子变化太快了,谁能告诉我 MCP 是什么
前端·后端·mcp
有什么东东36 分钟前
山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改
java·vue·bug·springboot
王月lydia37 分钟前
环境变量篇-vue3的H5项目从0到1工程化落地经验篇2
前端
赵要上天37 分钟前
利用TTP协议 ETag + 路由守卫 实现前端发版后通知用户更新得一个方案
前端
李剑一39 分钟前
写一个vitepress新建文章脚本,自动化创建链接,别再手写了!
前端·node.js·vitepress
火星思想40 分钟前
React如何实现时间切片
前端·react.js