All Projects → surmon-china → Vue Codemirror

surmon-china / Vue Codemirror

Licence: mit
⌨️ @codemirror component for @vuejs

Programming Languages

javascript
184084 projects - #8 most used programming language
Vue
7211 projects

Projects that are alternatives of or similar to Vue Codemirror

Vue Quill Editor
🍡@quilljs editor component for @vuejs
Stars: ✭ 6,874 (+225.01%)
Mutual labels:  text-editor, vue-components, vue-component, vuejs2, vue2, vue-plugin, vue-resource, vue-directive, web-editor
Vue Awesome Swiper
🏆 Swiper component for @vuejs
Stars: ✭ 12,072 (+470.78%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2, vue-plugin, vue-resource, vue-directive
Vue Touch Ripple
👆 Touch ripple component for @vuejs
Stars: ✭ 443 (-79.05%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2, vue-plugin, vue-resource
vue-drag-zone
Drag Zone component for @vuejs
Stars: ✭ 127 (-94%)
Mutual labels:  vue-components, vue2, vue-plugin, vue-component, vue-resource, vue-directive
Vue Video Player
🎞 @videojs component for @vuejs
Stars: ✭ 4,026 (+90.35%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2, vue-resource
Vue Form Json Schema
Create forms using JSON schema. Bring your components!
Stars: ✭ 253 (-88.04%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2
codemirror-editor-vue3
CodeMirror component for Vue3
Stars: ✭ 22 (-98.96%)
Mutual labels:  vue-components, codemirror, code-editor, web-editor
vue-notification-bell
Vue.js notification bell component.
Stars: ✭ 64 (-96.97%)
Mutual labels:  vuejs2, vue-components, vue2, vue-component
Quasar
Quasar Framework - Build high-performance VueJS user interfaces in record time
Stars: ✭ 20,090 (+849.88%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2
Vue Particles
Vue.js component for particles backgrounds ✨
Stars: ✭ 1,220 (-42.32%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2
Xcui
🍴 A Vue.js 2.x desktop components colletion
Stars: ✭ 88 (-95.84%)
Mutual labels:  vue-components, vue-component, vuejs2, vue2
Vue Toastr
Vuejs Toast : Plugin and Component Capability.
Stars: ✭ 93 (-95.6%)
Mutual labels:  vue-component, vuejs2, vue2, vue-plugin
Vuebar
(🗃️ Archived) Vue 2 directive for custom scrollbar that uses native scroll behavior. Lightweight, performant, customizable and without dependencies. Used successfully in production on https://ggather.com
Stars: ✭ 650 (-69.27%)
Mutual labels:  vuejs2, vue2, vue-directive
Vue Snotify
Vuejs 2 Notification Center
Stars: ✭ 755 (-64.3%)
Mutual labels:  vue-components, vuejs2, vue2
Semantic Ui Vue
Semantic UI integration for Vue
Stars: ✭ 914 (-56.78%)
Mutual labels:  vue-components, vuejs2, vue2
Vuesax
New Framework Components for Vue.js 2
Stars: ✭ 5,293 (+150.26%)
Mutual labels:  vue-components, vuejs2, vue2
Easy Vue
Learn vueJS Easily 👻
Stars: ✭ 896 (-57.64%)
Mutual labels:  vuejs2, vue2, vue-resource
Vue Share Buttons
🔗A set of social buttons for Vue.js
Stars: ✭ 34 (-98.39%)
Mutual labels:  vue-components, vuejs2, vue2
Vue Image Loader
Vue progressive image loader plugin like Medium
Stars: ✭ 47 (-97.78%)
Mutual labels:  vue-components, vuejs2, vue2
Vue Social Sharing
A renderless Vue.js component for sharing links to social networks, compatible with SSR
Stars: ✭ 1,071 (-49.36%)
Mutual labels:  vue-components, vue-component, vuejs2

GitHub stars Build Status GitHub issues GitHub forks GitHub last commit license

NPM NPM

vue-codemirror

CodeMirror component for Vue.

基于 CodeMirror,适用于 Vue 的 Web 代码编辑器。

Example

Events

To make it easier to handle events, the component converts some codemirror built-in native events into a single vue component event, where you can listen for events from both the component itself and from codemirror. If you need to listen for more and more complex events, you can pass in the event names (Array) you need for the global Vue.use(, { events: [] }) and the component parameters :events, respectively, or by the this.codemirror.on(event, hanger) method of the codemirror instance. Here's a list of events:

codemirror event list:

  • scroll
  • changes
  • beforeChange
  • cursorActivity
  • keyHandled
  • inputRead
  • electricInput
  • beforeSelectionChange
  • viewportChange
  • swapDoc
  • gutterClick
  • gutterContextMenu
  • focus
  • blur
  • refresh
  • optionChange
  • scrollCursorIntoView
  • update

component event list:

  • ready
  • input

Install

NPM

npm install vue-codemirror --save

# or
yarn add vue-codemirror

CDN

<link rel="stylesheet" href="path/to/codemirror/lib/codemirror.css">
<script type="text/javascript" src="path/to/codemirror.js"></script>
<script type="text/javascript" src="path/to/vue.min.js"></script>
<script type="text/javascript" src="path/to/dist/vue-codemirror.js"></script>
<script type="text/javascript" src="path/to/codemirror/{some-resources}"></script>
<script type="text/javascript">
  Vue.use(window.VueCodemirror)
</script>

Mount

mount with global

import Vue from 'vue'
import VueCodemirror from 'vue-codemirror'

// import base style
import 'codemirror/lib/codemirror.css'

// import more codemirror resource...

// you can set default global options and events when Vue.use
Vue.use(VueCodemirror, /* {
  options: { theme: 'base16-dark', ... },
  events: ['scroll', ...]
} */)

mount with component

import { codemirror } from 'vue-codemirror'

// import base style
import 'codemirror/lib/codemirror.css'

// import more codemirror resource...

export default {
  components: {
    codemirror
  }
}

Component

<template>
  <!-- Two-way Data-Binding -->
  <codemirror v-model="code" :options="cmOptions" />

  <!-- Or manually control the data synchronization -->
  <codemirror
    ref="cmEditor"
    :value="code"
    :options="cmOptions"
    @ready="onCmReady"
    @focus="onCmFocus"
    @input="onCmCodeChange"
  />

  <!-- Nuxt.js -->
  <client-only placeholder="Codemirror Loading...">
    <codemirror
      ref="cmEditor"
      :value="code" 
      :options="cmOptions"
      @ready="onCmReady"
      @focus="onCmFocus"
      @input="onCmCodeChange"
    />
  </client-only>
</template>

<script>
// import language js
import 'codemirror/mode/javascript/javascript.js'

// import theme style
import 'codemirror/theme/base16-dark.css'

// import more 'codemirror/some-resource...'

export default {
  data () {
    return {
      code: 'const a = 10',
      cmOptions: {
        tabSize: 4,
        mode: 'text/javascript',
        theme: 'base16-dark',
        lineNumbers: true,
        line: true,
        // more CodeMirror options...
      }
    }
  },
  methods: {
    onCmReady(cm) {
      console.log('the editor is readied!', cm)
    },
    onCmFocus(cm) {
      console.log('the editor is focused!', cm)
    },
    onCmCodeChange(newCode) {
      console.log('this is new code', newCode)
      this.code = newCode
    }
  },
  computed: {
    codemirror() {
      return this.$refs.cmEditor.codemirror
    }
  },
  mounted() {
    console.log('the current CodeMirror instance object:', this.codemirror)
    // you can use this.codemirror to do something...
  }
}
</script>

CodeMirror Merge

<template>
  <codemirror :merge="true" :options="cmOption" @scroll="onCmScroll" />
</template>

<script>
  // merge js
  import 'codemirror/addon/merge/merge.js'
  
  // merge css
  import 'codemirror/addon/merge/merge.css'
  
  // google DiffMatchPatch
  import DiffMatchPatch from 'diff-match-patch'
  
  // DiffMatchPatch config with global
  window.diff_match_patch = DiffMatchPatch
  window.DIFF_DELETE = -1
  window.DIFF_INSERT = 1
  window.DIFF_EQUAL = 0
  
  export default {
    data() {
      return {
        cmOption: {
          value: '<p>hello</p>',
          origLeft: null,
          orig: '<p>hello world</p>',
          connect: 'align',
          mode: 'text/html',
          lineNumbers: true,
          collapseIdentical: false,
          highlightDifferences: true
        }
      }
    },
    methods: {
      onCmScroll() {
        console.log('onCmScroll')
      }
    }
  }
</script>

Defined CodeMirror mode

import CodeMirror from 'codemirror'
CodeMirror.defineMode('mymode', () => {
  return {
    token(stream, state) {
      if (stream.match("const")) {
        return "style1"
      } else if (stream.match("bbb")) {
        return "style2"
      } else {
        stream.next()
        return null
      }
    }
  }
})

// Vue app...

CodeMirror language mode types

Codemirror language mode have string | object types.

// MIME types
mode: 'text/javascript'

// name
mode: {
  name: 'javascript',
  json: true
}

// ext
mode: {
  ext: 'js'
}

// mime
mode: {
  mime: 'text/javascript'
}

// filename
mode: {
  filename: 'index.js'
}

CodeMirror

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].