# VCodeDiff Vue2 / Vue3 可用的 code diff 插件 是 [vue-code-diff](https://github.com/ddchef/vue-code-diff) 的 vue3 版本, 参考了大幅代码,在这里表示感谢 # 如何安装? 安装 `v-code-diff` ```shell # With NPM npm i v-code-diff # With Yarn yarn add v-code-diff ``` Vue2 用户需要额外安装 composition-api ```shell yarn add @vue/composition-api ``` # 开始使用 ### `Vue3` #### 注册为全局组件 ```ts import {createApp} from 'vue' import CodeDiff from 'v-code-diff' app .use(CodeDiff) .mount('#app') ``` 然后 ```vue ``` #### 单独引入 在 vue 文件中 ```vue ``` ### `Vue2` #### 注册为全局组件 ```ts import Vue from 'vue'; import CodeDiff from 'v-code-diff' Vue.use(CodeDiff); ``` #### 单独引入 ```vue ``` # 事件 | 事件名称 | 说明 | 回调参数 | |---------- |-------- |---------- | | before-render | 渲染前触发 | - | | after-render | 渲染后触发 | - | # 参数 | 参数 | 说明 | 类型 | 可选值 | 默认值 | |---------- |-------- |---------- |------------- |-------- | | highlight | 控制是否高亮代码| boolean | - | true | | language | 代码语言,如 `typescript`。不填会自动判断。 [查看全部支持语言](https://github.com/highlightjs/highlight.js/blob/main/SUPPORTED_LANGUAGES.md)| string | - | - | | old-string| 陈旧的字符串| string | - | - | | new-string| 新的字符串| string | - | - | | context| 不同地方上下间隔多少行不隐藏 | number | - | - | | outputFormat| 展示的方式 | string | line-by-line,side-by-side | line-by-line | | drawFileList | 展示对比文件列表 | boolean | - | false | | renderNothingWhenEmpty | 当无对比时不渲染 | boolean | - | false | | diffStyle | 差异风格, 单词级差异或字母级差异 | string | word, char | word | | fileName | 文件名 | string | - | - | | isShowNoChange | 当无对比时展示源代码 | boolean | - | false | | trim | 移除字符串前后空白字符 | boolean | - | false | | language | 对比的文本语言 | boolean | - | false | | noDiffLineFeed | 不 diff windows 换行符(CRLF)与 linux 换行符(LF) | boolean | - | false | # 与 vue-code-diff 的不同 * 支持 `vue3` * 更小的打包体积 * 更快的渲染速度 # 变更记录 ### 0.3.8 1. 样式调整,隐藏 css `d2h-file-header`,对齐 vue-code-diff 2. 添加 prop `noDiffLineFeed`,不 diff windows 换行符(CRLF)与 linux 换行符(LF) ### 0.3.7 1. 修复当 isShowNoChange 为 true 时,而新旧代码不同时仍展示 “File Without Change” 的问题。然后展示全部源代码 ### 0.3.6 1. 添加 prop `language`,能让高亮更准确 ### 0.3.5 1. side-by-side 模式中,支持左右同步滚动 ### 0.3.4 1. 增加 Prop `trim`, 可以移除字符串前后空白字符 ### 0.3.3 1. 修复了 highlight 失效的问题 ### 0.3.2 1. 修复了 vue2 用户的控制台警告 ### 0.3.1 1. 修复了 diff 时样式显示 bug ### 0.3.0 1. 性能优化,现在渲染拥有更好的性能 2. 添加 Prop `diffStyle` 来控制是否显示单词级差异还是字母级差异 ### 0.2.1 1. 使用异步渲染高亮代码的功能,不阻塞 ui,极大提升页面渲染速度 2. 增加钩子函数(渲染前,渲染后): `before-render`, `after-render` ### 0.1.0 1. 添加 Prop `highlight` 来控制是否高亮代码 ### 0.0.4 1. 修复一些浏览器下渲染异常的问题(例如 safari) ### 0.0.3 1. Prop: `context` 默认值由 5 改为 10 2. 修复可能存在的 line-height 冲突 (如 [antd-vue](https://github.com/vueComponent/ant-design-vue) 的 `antd.css` ) ### 0.0.1 第一个版本. # LICENCE MIT License Copyright (c) 2021 Shimada666 Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.