Using the TinyMCE package with the Vue.js framework

The Official TinyMCE Vue.js component integrates TinyMCE into Vue.js projects. This procedure creates a basic Vue.js application containing a TinyMCE editor.

Version 4 of the tinymce-vue package supports Vue.js 3.x, but does not support Vue.js 2.x. For Vue.js 2.x applications, use tinymce-vue version 3.

TinyMCE Vue.js integration live examples

For examples of the TinyMCE Vue.js 3.x integration:

  1. Clone the tinymce/tinymce-vue GitHub repository. For example:

    git clone
  2. Install the required packages using yarn. For example:

    yarn install
  3. To start the demo server, run:

    yarn demo

The tinymce-vue demo is now running. Visit: http://localhost:3001.


This procedure requires Node.js (and npm).


  1. On a command line or command prompt, install the Vue CLI Tool package.

    npm install -g @vue/cli
  2. Create a new Vue.js project named tinymce-vue-demo.

    • To use the interactive prompt, run:

      vue create tinymce-vue-demo
    • To skip the interactive prompt:

      • For Vue.js 3.x users:

        vue create --inlinePreset '{ "vueVersion": "3", "plugins": {} }' tinymce-vue-demo
      • For Vue.js 2.x users:

        vue create --inlinePreset '{ "vueVersion": "2", "plugins": {} }' tinymce-vue-demo
  3. Change into the newly created directory.

    cd tinymce-vue-demo
  4. Install the tinymce and tinymce-vue packages and save them to your package.json with --save.

    • For Vue.js 3.x users:

      npm install --save tinymce "@tinymce/tinymce-vue@^4"
    • For Vue.js 2.x users:

      npm install --save tinymce "@tinymce/tinymce-vue@^3"
  5. Using a text editor, open /path/to/tinymce-vue-demo/src/App.vue.

    1. Add a TinyMCE configuration to the <template> using the <editor> tag.

    2. Add import Editor from '@tinymce/tinymce-vue' to the start of the <script>.

    3. Add editor: Editor to the default {components}.

      For example:

        <div id="app">
          <img alt="Vue logo" src="./assets/logo.png">
              plugins: 'lists link image table code help wordcount'
      import Editor from '@tinymce/tinymce-vue'
      export default {
        name: 'app',
        components: {
          'editor': Editor
  6. Bundle TinyMCE with the Vue.js application using a module loader (such as Webpack).

    Tiny does not recommend bundling tinymce and tinymce-vue with a module loader. Bundling these packages can be complex and error prone.

    To bundle TinyMCE using a module loader (such as Webpack, Rollup, or Browserify), import or require the tinymce package, followed by the tinymce-vue package, then the other required TinyMCE-related imports.

    Example of bundling:

    /* Add the tinymce-vue wrapper to the bundle */
    import { Editor } from '@tinymce/tinymce-vue';
    /* For instructions on bundling TinyMCE, see the Bundling TinyMCE documentation. */

    For instructions on bundling TinyMCE, see: Bundling TinyMCE.

  7. Test the application using the Node.js development server.

    • To start the development server, navigate to the tinymce-vue-demo directory and run:

      npm run serve
    • To stop the development server, select on the command line or command prompt and press Ctrl+C.

Deploying the application to a HTTP server

The application will require further configuration before it can be deployed to a production environment. For information on configuring the application for deployment, see: Vue.js - Production Deployment.

Next Steps