Vue Wrapper for the Jodit Editor
Install Jodit Vue:
npm install jodit-vue --save
// or with Yarn
yarn add jodit-vue
Since this component is just a wrapper, you need to include the css
of the Jodit Editor on your app for it to work properly, if you're using vue-cli
to create your app, or another build system you can import it directly or add a link
tag with the css
file provided by the Jodit Editor package.
import 'jodit/build/jodit.min.css'
import Vue from 'vue'
import JoditVue from 'jodit-vue'
Vue.use(JoditVue)
Instead of using Vue.use(JoditVue)
you can use the component locally
<template>
<div id="app">
<jodit-vue v-model="content" />
</div>
</template>
<script>
import 'jodit/build/jodit.min.css'
import JoditVue from 'jodit-vue'
export default {
name: 'app',
components: { JoditVue },
data () {
return {
content: '<h1>Hello Jodit Vue</h1>'
}
}
}
</script>
You can check and test it on Codesanbox too.
If you don't use a build system on your app, you can also use Jodit Vue without problems, check and test it on this JsFiddle.
If you pass only the v-model
for the component, it will load all the editor features, if you want to customize it, you can do it with its properties that are listed below, but all of them are not required, just if you want to customize your editor that you will need them:
Property | Type | Default Value | Description |
---|---|---|---|
id | String | 'editor' | The ID of the editor div wrapper, you need to specify it if you want to mount more than one editor on the same page |
buttons | Array | null |
The buttons that you want to show on toolbar, if this is not provided, all the buttons will be shown |
extraButtons | Array | null |
If you need to create and display custom buttons you can pass an array with your custom buttons to this property |
config | Object | {} |
The config object that has all the other configurations for the editor |
When providing the buttons to show on the editor you will need to provide an array with the buttons that you want to show. The button names can be found here. You can also pass a |
to put a divider between the buttons.
<template>
<div id="app">
<jodit-vue v-model="content" :buttons="buttons" />
</div>
</template>
<script>
import 'jodit/build/jodit.min.css'
import JoditVue from 'jodit-vue'
export default {
name: 'app',
components: { JoditVue },
data () {
return {
content: '<h1>Hello Jodit Vue</h1>',
buttons: ['source', 'image', '|', 'bold', 'underline', 'italic']
}
}
}
</script>
If you need to create custom buttons to the editor, you can create them and provide the component with an array
<template>
<div id="app">
<jodit-vue v-model="content" :buttons="buttons" :extra-buttons="customButtons" />
</div>
</template>
<script>
import 'jodit/build/jodit.min.css'
import JoditVue from 'jodit-vue'
export default {
name: 'app',
components: { JoditVue },
data () {
return {
content: '<h1>Hello Jodit Vue</h1>',
buttons: ['source', 'image', '|', 'bold', 'underline', 'italic'],
customButtons: [
{
name: 'insertDate',
iconURL: 'http://xdsoft.net/jodit/logo.png',
exec: function (editor) {
editor.selection.insertHTML((new Date).toDateString());
}
}
]
}
}
}
</script>
To create custom buttons, check the Jodit Editor Docs
This config allows you to pass all the other configurations found here to customize your editor.
Thanks goes to these wonderful people (emoji key):
Wendell Adriel 💻 📖 💡 🤔 |
---|
This project follows the all-contributors specification. Contributions of any kind welcome!