jExcel

Lightweight vanilla JavaScript plugin to create web-based spreadsheets comp...

README

Jspreadsheet CE v4: The JavaScript spreadsheet

Jexcel CE has been renamed to Jspreadsheet CE

- Important: Please import jspreadsheet.css (jexcel.css is not longer available in this package).
[Jspreadsheet CE](https://bossanova.uk/jspreadsheet/v4/) is a lightweight Vanilla JavaScript data grid plugin to create amazing web-based interactive HTML tables, and spreadsheets compatible data grid with other spreadsheet software. You can create an online spreadsheet table from a JS array,
JSON, CSV or XSLX files. You can copy from excel and paste straight to your Jspreadsheet CE spreadsheet and vice versa.
It is very easy to integrate any third party JavaScript plugins to create your own custom columns, custom editors, and customize any
feature into your application. Jspreadsheet CE has plenty of different input options through its native column types to cover the most common web-based application
requirements. It is a complete solution for web data management. Create amazing applications with Jspreadsheet CE JavaScript spreadsheet.

Jspreadsheet Pro v9 - Commercial Solutions

Main advantages

- Make rich and user-friendly web interfaces and applications.
- You can easily handle complicated data inputs in a way users are used..
- Improve your user software experience.
- Create rich CRUDS and beautiful UI.
- Compatibility with excel: users can move data around with common copy and paste shortcuts.
- Easy customizations with easy third-party plugin integrations.
- Lean, fast and simple to use.
- Thousands of successful user cases.
- Speed up your work dealing with difficult data entry in a web-based software.

Screenshot

The JavaScript spreadsheet

Installation

As node package

npm install jspreadsheet-ce

As standalone library/js plugin

put and use the files of dist folder in your project (js library and css files)

With a framework

See examples section for code examples of jspreadsheets with popular frameworks

Basic demo

A basic example to integrate the JavaScript spreadsheet in your website to create your first online spreadsheet.

Usage

Add jexcel/jspreadsheet and jsuites to your html file
  1. ``` html
  2. <script src="https://bossanova.uk/jspreadsheet/v4/jexcel.js"></script>
  3. <script src="https://jsuites.net/v4/jsuites.js"></script>
  4. <link rel="stylesheet" href="https://jsuites.net/v4/jsuites.css" type="text/css" />
  5. <link rel="stylesheet" href="https://bossanova.uk/jspreadsheet/v4/jexcel.css" type="text/css" />
  6. ```
You should initialize your table based on a div container, such as:
  1. ``` html
  2. <div id="spreadsheet"></div>
  3. ```
To initialize a Jspreadsheet CE table you should run JavaScript, such as:
  1. ``` js
  2. var data = [
  3.     ['Jazz', 'Honda', '2019-02-12', '', true, '$ 2.000,00', '#777700'],
  4.     ['Civic', 'Honda', '2018-07-11', '', true, '$ 4.000,01', '#007777'],
  5. ];
  6. jspreadsheet(document.getElementById('spreadsheet'), {
  7.     data:data,
  8.     columns: [
  9.         { type: 'text', title:'Car', width:120 },
  10.         { type: 'dropdown', title:'Make', width:200, source:[ "Alfa Romeo", "Audi", "Bmw" ] },
  11.         { type: 'calendar', title:'Available', width:200 },
  12.         { type: 'image', title:'Photo', width:120 },
  13.         { type: 'checkbox', title:'Stock', width:80 },
  14.         { type: 'numeric', title:'Price', width:100, mask:'$ #.##,00', decimal:',' },
  15.         { type: 'color', width:100, render:'square', }
  16.     ]
  17. });
  18. ```
Serve your html file and then you will get the rendered table in your browser
sampleTable

Development

Examples

Simple demo (as in codepen)
Demo using library from dist folder, ready to use for development of jspreadsheet
A full example on how to integrate Jspreadsheet CE with React.
A full example on how to integrate Jspreadsheet CE with Vue.
Full spreadsheet example with search and pagination to bring great compatibility for those who love datatables.
Learn more about the powerful column types. This example brings all native column types and how to create your own custom type.
Full examples on how to handle simple, advanced, multiple, autocomplete and conditional dropdowns. Create amazing JavaScript tables using categories and images in your dropdowns.
Example from basic to advanced calendar usage, date and datetime picker.
This examples shows how to upload images to your spreadsheet.
How to update your spreadsheet and its data by JavaScript.
Bring a very special touch to your applications customizing your JavaScript spreadsheet.
Learn how to handle events on Jspreadsheet CE.
How to import data from an external CSV, json file or XLSX.
Unleash the power of your tables bringing formulas and custom JavaScript methods on your Jspreadsheet spreadsheet.
Full example on how to enable nor customize your JavaScript spreadsheet toolbar.
Allow comments in your table spreadsheet.
Enabled nested headers in your spreadsheet and learn how to set or get header values.
How to translate the default messages from Jspreadsheet.
Full example on how to handle merge cells in your JavaScript tables.
Example how to sort the table by a column via JavaScript.
This example brings a very nice feature to deal with large table datasets.

Jspreadsheet CE History

Jspreadsheet CE 4.6

Jexcel has been renamed to Jspreadsheet

Jspreadsheet CE 4.0.0

A special thank to the FDL - Fonds de Dotation du Libre support and sponsorship that make this version possible with so many nice features.
- Support workbooks/tabs
- Create a dymic jexcel table from a HTML static element
- Highlight the border from cells after CTRL+C
- Footer with formula support
- Multiple columns resize
- JSON update support (Helpers to update a remote server)
- Global super event (centralized method to dispatch all events in one)
- Custom helpers: =PROGRESS (progressbar), =RATING (5 star rating)
- Custom helpers: =COLUMN, =ROW, =CELL, =TABLE, =VALUE information to be used on formula execution
- Dynamic nested header updates
- A new column type for HTML editing
- New flags such as: includeHeadersOnCopy, persistance, filters, autoCasting, freezeColumns
- New events such as: onevent, onchangepage, onbeforesave, onsave
- More examples and documentation

Jspreadsheet CE 3.9.0 (Jexcel)

- New methods
- General fixes

Jspreadsheet CE 3.6.0 (Jexcel)

- Better formula parsing
- New events
- New initialization options
- General fixes

Jspreadsheet CE 3.2.3 (Jexcel)

- getMeta, setMeta methods
- Npm package with jSuites
- General fixes

Jspreadsheet CE 3.0.1 (Jexcel)

Jspreadsheet CE v3 is a complete rebuilt JavaScript Vanilla version. For that reason it was not possible to keep a
complete compatibility with the previous version. If you are upgrading you might need to implement a few updates in your code.
If you have questions, you can review the article upgrading from Jspreadsheet CE v2 or Handsontable.
The Jspreadsheet CE v3 brings lot of great new features:
- Drag and drop columns.
- Resizable rows.
- Merge columns.
- Search.
- Pagination.
- Lazy loading.
- Full screen flag.
- Image upload.
- Native color picker.
- Better mobile compatibility.
- Better nested headers compatibility.
- Amazing keyboard navigation support.
- Better hidden column management.
- Great data picker: dropdown, autocomplete, multiple, group options and icons.
- Importing from XLSX (experimental).
Big improvements are included, such as:
- Complete new formula engine with no external dependencies with much faster results.
- Absolutely no selectors, means a much faster application.
- New native columns.
- jQuery is not required anymore.
- React, Vue and Angular examples.
- XLSX support using a custom sheetjs (experimental).

Jspreadsheet CE 2.1.0 (Jexcel)

We are glad to bring you the latest jQuery plugin version, with the following improvements:
- Mobile touch fixes.
- Paste fixes & New CSV parser.

Jspreadsheet CE 2.0.0 (Jexcel)

- New radio column.
- New dropdown with autocomplete and multiple selection options.
- Header/body separation for a better scroll/column resize behavior and compatibility.
- Better text-wrap including alt+enter excel compatibility.
- New set/get meta information.
- New set/get config parameters.
- New set/get programmatically cell style.
- New set/get cell comments.
- New table custom toolbar.
- New responsive calendar picker.

Jspreadsheet CE 1.5.7 (Jexcel)

- Checkbox column type improvements.
- Destroy jQuery table updates.

Jspreadsheet CE 1.5.1 (Jexcel)

- Spreadsheet data overflow and fixed headers. See an example.
- Navigation improvements.

Jspreadsheet CE 1.5.0 (Jexcel)

- Relative insertRow, deleteRow, insertColumn, deleteColumn.
- Redo, Undo action tracker for insertRow, deleteRow, insertColumn, deleteColumn, moveRow.
- New formula column recursive chain.
- New alternative design option bootstrap-like.
- updateSettings updates.

Official websites

Community

Contributing

Copyright and license

Jspreadsheet CE is released under the [MIT license]. Contact contact@jspreadsheet.com

Other tools

jSuites

Image cropper

Documentation

Examples

Integrations

Javascript Template

Documentation

Examples

  Basic

JavaScript Organogram

Documentation

Examples

  Basic

Integrations

Javascript Heatmap

Documentation

Examples

  Basic
  Colors

Core features

Core

  Toast

Helpers

JavaScript Dropdown

Documentation

Examples

  Basic
  Images
  Colors
  Events

Integrations

JavaScript Calendar

Documentation

Examples

  Basic
  Events

Integrations

Tags and keywords

Documentation

Examples

  Basic
  Events

Integrations

JavaScript tabs plugin

Documentation

Examples

  Basic
  Style
  Events

Color picker plugin

Documentation

Examples

  Basic
  Events

Examples

Context menu plugin

Documentation

Examples

  Basic
  Icons

Input mask plugin

Documentation

Examples

  Basic
  Events

JavaScript Modal

Documentation

Examples

  Basic
  Events

Rich HTML Forms

Documentation

Examples

JavaScript rating plugin

Documentation

Examples

  Events

Integrations

JavaScript toolbar

Documentation

Examples

Text editor plugin

Documentation

Examples

  Basic

Picker plugin

Documentation

Examples

  Basic

Integrations

Image slider plugin

Documentation

Examples

  Basic

All Components

Core

  Toast

Extensions

Components

  Mask
  Modal
  Picker
  Rating
  Slider
  Tags
  Tabs