Vue2 / Vue3 可用的 code diff 插件
English | 简体中文
旧版本:
- 0.x 版本, 最新版本 0.3.12 (传统版本,基于 vue-code-diff 进行改进,目前不再进行维护,我们会在 1.x 版本尽量对齐 0.x 版本功能,尽量降低迁移成本)
本项目参考了以下项目,在此对原作者表示感谢!
- vue-diff
- vue-code-diff
- Github Code Diff
安装 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
推荐使用,因为对 tree-shaking 有更好的支持。
<script setup>
import { CodeDiff } from 'v-code-diff'
</script>
<template>
<div>
<CodeDiff
old-string="12345"
new-string="3456"
output-format="side-by-side"
/>
</div>
</template>
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>
推荐使用,因为对 tree-shaking 有更好的支持。
<script>
import { CodeDiff } from 'v-code-diff'
export default {
components: {
CodeDiff
}
}
</script>
<template>
<div>
<CodeDiff
old-string="12345"
new-string="3456"
output-format="side-by-side"
/>
</div>
</template>
import Vue from 'vue'
import CodeDiff from 'v-code-diff'
Vue.use(CodeDiff)
npm | cdn | |
---|---|---|
vue2 | vue2-cdn | |
vue2.7 | vue27-cdn | |
vue3 | vue3-cdn |
参数 | 说明 | 类型 | 可选值 | 默认值 |
---|---|---|---|---|
language | 代码语言,如typescript ,默认纯文本。 查看全部支持语言 |
string | - | plaintext |
oldString | 旧的字符串 | string | - | - |
newString | 新的字符串 | string | - | - |
context | 不同地方上下间隔多少行不隐藏 | number | - | 10 |
outputFormat | 展示方式 | string | line-by-line,side-by-side | line-by-line |
diffStyle | 差异风格, 单词级差异或字母级差异 | string | word, char | word |
forceInlineComparison | 细分差异;存在差异时,强制进行行内对比(word 或 char 级) | boolean | - | false |
trim | 移除字符串前后空白字符 | boolean | - | false |
noDiffLineFeed | 不 diff windows 换行符(CRLF)与 linux 换行符(LF) | boolean | - | false |
maxHeight | 组件最大高度,例如 300px | string | - | undefined |
filename | 文件名 | string | - | undefined |
newFilename | 新文件文件名 | string | - | undefined |
hideHeader | 隐藏头部栏 | boolean | - | false |
hideStat | 隐藏头部栏中的统计信息 | boolean | - | false |
theme | 用于切换日间模式/夜间模式 | ThemeType | light , dark | light |
ignoreMatchingLines | 给出一个模式来忽略匹配行,例如:'(time|token)' | string | - |
Name | Description | Type |
---|---|---|
diff | diff 完成后触发 | (result: {stat: { isChanged: boolean, addNum: number, delNum: number}}) => void |
Name | Description |
---|---|
stat | 自定义统计内容,参数为 { stat } |
为了减小打包后的体积,系统默认仅支持以下常用语言
- plaintext
- xml/html
- javascript
- json
- yaml
- python
- java
- bash
- sql
如果您需要的语言不在其中,可以手动引入相关的语言高亮模块
pnpm add highlight.js
推荐使用,因为对 tree-shaking 有更好的支持。
<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>
<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>
import CodeDiff from "v-code-diff"
// Extend C language
import c from "highlight.js/lib/languages/c"
CodeDiff.hljs.registerLanguage("c", c)
v-code-diff 的 1.x 版本相较于 0.x 版本,具有打包体积减小、性能提升等特性。并且我们会在功能上尽量对齐 0.x 版本,降低您的迁移成本。
重点:
- 1.x 版本中,不再会自动识别语言并高亮,您需要手动指定语言类型,如
language="python"
,若不指定则默认为纯文本plaintext
,不会进行高亮。 - 1.x 版本中,由于渲染和高亮是同时进行,因此移除了组件事件
- 1.x 版本中,以下组件属性(Prop)有变动
- highlight - 移除
- drawFileList - 移除
- fileName - 更名为 filename
- newFilename - 新增
- theme - 新增
以下是两个版本具体的差异点,您可以参照阅读完成迁移。
1.x 版本中,由于渲染与高亮是同时进行,因此不再提供组件事件
事件名称 | 说明 |
---|---|
before-render | 不再提供 |
after-render | 不再提供 |
参数 | 含义 | 变更情况 |
---|---|---|
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 版本新增 |