当前位置: 首页 > article >正文

v-code-diff 配置

Vue2 / Vue3 可用的 code diff 插件

演示地址: https://shimada666.github.io/v-code-diff/

目录

  • 安装
  • 开始使用
    • Vue3
    • Vue2
  • 组件属性
  • 组件事件
  • 拓展高亮语言
  • 从 0.x 版本迁移

安装

安装 v-code-diff

# npm
npm i v-code-diff

# yarn
yarn add v-code-diff

# pnpm
pnpm add v-code-diff

Vue2.6 及以下用户需要额外安装 composition-api

pnpm add @vue/composition-api

开始使用

Vue3

单独引入

推荐使用,因为对 tree-shaking 有更好的支持。

<template>
  <div>
    <CodeDiff
      old-string="12345"
      new-string="3456"
      output-format="side-by-side"
    />
  </div>
</template>

<script setup>
import { CodeDiff } from 'v-code-diff'
</script>
注册为全局组件
import { createApp } from 'vue'
import CodeDiff from 'v-code-diff'

app.use(CodeDiff).mount('#app')

然后

<template>
  <code-diff
    old-string="12345"
    new-string="3456"
    output-format="side-by-side"
  />
</template>

Vue2

单独引入

推荐使用,因为对 tree-shaking 有更好的支持。

<template>
  <div>
    <CodeDiff
      old-string="12345"
      new-string="3456"
      output-format="side-by-side"
    />
  </div>
</template>

<script>
import { CodeDiff } from 'v-code-diff'
export default {
  components: {
    CodeDiff
  }
}
</script>
注册为全局组件
import Vue from 'vue'
import CodeDiff from 'v-code-diff'

Vue.use(CodeDiff)

组件属性

参数说明类型可选值默认值
language代码语言,如typescript,默认纯文本。 查看全部支持语言string-plaintext
oldString旧的字符串string--
newString新的字符串string--
context不同地方上下间隔多少行不隐藏number-10
outputFormat展示方式stringline-by-line,side-by-sideline-by-line
diffStyle差异风格, 单词级差异或字母级差异stringword, charword
forceInlineComparison细分差异;存在差异时,强制进行行内对比(word 或 char 级)boolean-false
trim移除字符串前后空白字符boolean-false
noDiffLineFeed不 diff windows 换行符(CRLF)与 linux 换行符(LF)boolean-false
maxHeight组件最大高度,例如 300pxstring-undefined
filename文件名string-undefined
newFilename新文件文件名string-undefined
hideHeader隐藏头部栏boolean-false
hideStat隐藏头部栏中的统计信息boolean-false
theme用于切换日间模式/夜间模式ThemeTypelight , darklight
ignoreMatchingLines给出一个模式来忽略匹配行,例如:‘(time|token)’string-

组件事件

NameDescriptionType
diffdiff 完成后触发(result: {stat: { isChanged: boolean, addNum: number, delNum: number}}) => void

组件插槽

NameDescription
stat自定义统计内容,参数为 { stat }

拓展高亮语言

为了减小打包后的体积,系统默认仅支持以下常用语言

  • plaintext
  • xml/html
  • javascript
  • json
  • yaml
  • python
  • java
  • bash
  • sql

如果您需要的语言不在其中,可以手动引入相关的语言高亮模块

pnpm add highlight.js
单独引入

推荐使用,因为对 tree-shaking 有更好的支持。

<template>
  <div>
    <CodeDiff
      old-string="#include <stdio.h>"
      new-string="#include <stdio.h>\nint a = 1;"
      output-format="side-by-side"
      language="c"
    />
  </div>
</template>

<script>
import { CodeDiff, hljs } from 'v-code-diff'
import c from 'highlight.js/lib/languages/c'
// Extend C language
hljs.registerLanguage('c', c)
export default {
  components: {
    CodeDiff,
  }
}
</script>
全局注册
import CodeDiff from "v-code-diff"
// Extend C language
import c from "highlight.js/lib/languages/c"

CodeDiff.hljs.registerLanguage("c", c)

组件属性对比

参数含义变更情况
highlight控制是否高亮代码1.x 版本移除
language代码语言
old-string旧的字符串
new-string新的字符串
context不同地方上下间隔多少行不隐藏
output-format展示方式
diff-style差异风格, 单词级差异或字母级差异
drawFileList展示对比文件列表1.x 版本移除
renderNothingWhenEmpty当无对比时不渲染1.x 版本移除
fileName文件名1.x 版本更名为 filename
newFilename新文件文件名1.x 版本新增
isShowNoChange当无对比时展示源代码1.x 变为默认情况,故移除
trim移除字符串前后空白字符
noDiffLineFeed忽视不同系统换行符差异
theme用于切换日间模式/夜间模式1.x 版本新增

http://www.kler.cn/a/576314.html

相关文章:

  • HTML 属性详解:为网页元素赋予更多功能
  • 设计模式--单例模式(Singleton)【C++】
  • 分布式存储学习——HBase概述
  • linux上安装redis[从0到1]
  • Jenkins在Windows上的使用(二):自动拉取、打包、部署
  • 【uniapp】图片添加canvas水印
  • FFmpeg入门:最简单的音视频播放器
  • Docker 部署
  • 六、Redis 高级功能详解:BitMap、HyperLogLog、Geo、Stream
  • Webpack、Parcel、Rollup、esbuild、Vite、Next.js前端构建工具
  • 分布式泵站无线统管终极方案:1站1机,GRM242Q-C集群直通中控大屏(老型号GRM232Q-C)
  • 米尔基于STM32MP25x核心板Debian系统发布,赋能工业设备
  • 轻闪PDF(Windows傲软PDF编辑软件)2.15.2中文安装版
  • 重塑未来:生成式AI如何重构企业数据基因?三大技术重构的生死局
  • Swift系列01-Swift语言基本原理与设计哲学
  • T31ZC 君正SOC芯片 应用于智能家居、工业控制等 满足各种嵌入式应用的需求 提供样品测试+软硬件资料
  • 奇安信 2025 年护网蓝队初选笔试题(附答案解析)
  • 物联网 全部技术栈和实现方案
  • vue3中emits
  • Linux15-epoll、数据库