vue-editor-js
vue-editor-js is editorjs wrapper component.
Please see this first. https://editorjs.io/
For before 2.0.0 version users.
This plugins is turned to be just wrapper component. If you need to use plugin for editor.js, just import and set to config property.
Please See the Demo.vue
For before 1.0.0 version users.
Please Vue.use vue-editor-js in main.js.
Supported Plugins
- Personality
- Header
- List
- Image
- InlineCode
- Embed
- Quote
- Marker
- Code
- Link
- Delimiter
- Raw
- Table
- Warning
- Paragraph
- Checklist
Installation
npm install --save vue-editor-js
# or Yarn
yarn add vue-editor-jsUsage
// In main.js
// ...
import Editor from 'vue-editor-js'
Vue.use(Editor)
// ...// on Nuxt.js
// in nuxt.config.js
plugins: [
{
src: '~/plugins/vue-editor.js', ssr: false
}
],
// in ~/plugins/vue-editor.js
import Vue from 'vue'
import Editor from 'vue-editor-js'
Vue.use(Editor) <editor ref="editor" :config="config" :initialized="onInitialized"/>define initialize Function for get instance of editor.js when initialized
If you confused using on Nuxt, please see here
Local import
You can import Editor only in components where you need it.
- Make sure to install
@vue/composition-api
npm i --save @vue/composition-api
#or Yarn
yarn add @vue/composition-api- In main.js:
import Vue from 'vue'
import VueCompositionApi from '@vue/composition-api'
Vue.use(VueCompositionApi)- Don't import anything from
'vue-editor-js'in main.js - In your component:
import { Editor } from 'vue-editor-js'
export default {
// ...
components: {
Editor,
},
// ...
}Tools
Supported tools
Same as in Supported Plugins, but with different naming
- header
- list
- code
- inlineCode
- personality
- embed
- linkTool
- marker
- table
- raw
- delimiter
- quote
- image
- warning
- paragraph
- checklist
Usage
<editor header list code ... :config="config"/>Upload Image (>= 1.1.0)
for upload image, You need a backend for processing image. vue-editor-js provide special config props for easy.
If you server for test upload image, please see server example.
<editor :config="config" />
<script>
...
data() {
return {
config: {
image: {
// Like in https://github.com/editor-js/image#config-params
endpoints: {
byFile: 'http://localhost:8090/image',
byUrl: 'http://localhost:8090/image-by-url',
},
field: 'image',
types: 'image/*',
},
}
}
}
</script>upload personality avatar ( >= 2.0.1)
config: {
personality: {
endpoints: 'http://localhost:8090/image'
}Other props:
- customTools - Object with name (key) and class of a custom tool (value)
Enjoy editorjs with Vue.js Project
How to Contribute?
- fork this project.
- edit code.
- PR
OR
- Just submit a issue!

Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.

