Coder Social home page Coder Social logo

lsim / vue2-codemirror-lite-js Goto Github PK

View Code? Open in Web Editor NEW

This project forked from sireniaeu/vue2-codemirror-lite-js

0.0 2.0 0.0 1.07 MB

๐ŸŽฉ Lightweight CodeMirror component for Vue.js 2.x (JS only with linting via JSHINT)

Home Page: https://sireniaeu.github.io/vue2-codemirror-lite-js/

Vue 71.78% JavaScript 13.76% CSS 14.46%

vue2-codemirror-lite-js's Introduction

Vue2 Codemirror Lite

CodeMirror component for Vue.js 2.x, configured for linting & js mode only to keep it light.

Vue2 Codemirror for JS screenshot

Motivation

For applications that only use CodeMirror for JavaScript, the bundle size can seriously be decreased by eliminating some of the features, themes and modes.

This is not a fully-featured CodeMirror plugin (that's why it's lite). If you are looking for that, please check out vue-codemirror.

Most things are pre-configured (i.e. mode, theme), but additional CodeMirror options can be set (see Codemirror config APIs).

What's inside

  • JavaScript only mode (not configurable)
  • lint via JSHINT (bundled, not configurable)
  • dark theme only (slightly modified neo, see demo.)
  • line numbers, line wrapping
  • accepts additional CodeMirror options (see some here), except for mode, theme & those that require addons.

Getting started

Installing

npm install vue2-codemirror-lite-js --save # yarn add vue2-codemirror-lite-js

Usage

// Require in Webpack.
var Vue = require('vue')
var CodeMirrorLiteJs = require('vue2-codemirror-lite-js')

Vue.use(CodeMirrorLiteJs)


// Or use as component (ES6)
import Vue from 'vue'
import { codemirror } from 'vue2-codemirror-lite-js'

export default {
  components: {
    codemirror
  }
}

Usage in template

<!-- simple -->
<codemirror :code="code"></codemirror>

<!-- simple (with bindings) -->
<codemirror v-model="code"></codemirror>

<!-- advanced -->
<codemirror
    :code="code"
    :options="{
       tabSize: 2,
       lineNumbers: true,
       lineWrapping: true,
       line: true,
       gutters: ['CodeMirror-linenumbers', 'CodeMirror-lint-markers'],
       lint: true
    }"
    :lintOptions="{
        sub: true,
        notypeof: true
    }"
    @changed="yourCodeChangeMethod">
</codemirror>

Lint options are equivalent to JSHINT options (or what you'd normally put in .jshintrc). See all the options here

There's also a code example available in the source.

Developing

There's a simple webpack config setup to get you started.

Build / watch

npm run build

Run the example

npm run serve

Feel free to contribute to the build config and make it better :)

Contributing

Contributions are welcome for additional options, themes and modes that don't increase the bundle size. Ideally, if you want to contribute split your code.

Changelog

#####v3.0.6

  • Moved to Sireniaeu

#####v3.0.5

  • Added watcher for replaceRange, essentially allowing to replace or insert text at line & ch.

#####v3.0.4

  • Added lint options for jshint (.jshintrc-like)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.