Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lovasoa/react-contenteditable
React component for a div with editable contents
https://github.com/lovasoa/react-contenteditable
contenteditable editing html react react-component text wysiwyg
Last synced: 5 days ago
JSON representation
React component for a div with editable contents
- Host: GitHub
- URL: https://github.com/lovasoa/react-contenteditable
- Owner: lovasoa
- License: apache-2.0
- Created: 2014-12-28T16:29:46.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2023-03-15T11:39:58.000Z (almost 2 years ago)
- Last Synced: 2024-10-29T15:35:14.321Z (3 months ago)
- Topics: contenteditable, editing, html, react, react-component, text, wysiwyg
- Language: TypeScript
- Homepage: http://npmjs.com/package/react-contenteditable
- Size: 2.33 MB
- Stars: 1,631
- Watchers: 13
- Forks: 218
- Open Issues: 48
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-components-all - react-contenteditable - React component for a div with editable contents. (Uncategorized / Uncategorized)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- awesome-react - react-contenteditable - React component for a div with editable contents. ![](https://img.shields.io/github/stars/lovasoa/react-contenteditable.svg?style=social&label=Star) (UI Components / Form Components)
- awesome-list - react-contenteditable - React component for a div with editable contents. (Demos / Form Components)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- fucking-awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
- awesome-react-components - react-contenteditable - React component for a div with editable contents. (UI Components / Form Components)
README
react-contenteditable
=====================React component for a div with editable contents
[![Build Status](https://travis-ci.org/lovasoa/react-contenteditable.svg?branch=master)](https://travis-ci.org/lovasoa/react-contenteditable)
[![download count](https://img.shields.io/npm/dm/react-contenteditable.svg)](https://www.npmjs.com/package/react-contenteditable)
[![bundle size](https://img.shields.io/bundlephobia/minzip/react-contenteditable.svg)](https://www.npmjs.com/package/react-contenteditable)
[![license](https://img.shields.io/github/license/lovasoa/react-contenteditable.svg)](https://github.com/lovasoa/react-contenteditable/blob/master/LICENSE)## Install
```sh
npm install react-contenteditable
```## Usage
```javascript
import React from 'react'
import ContentEditable from 'react-contenteditable'class MyComponent extends React.Component {
constructor() {
super()
this.contentEditable = React.createRef();
this.state = {html: "Hello World"};
};handleChange = evt => {
this.setState({html: evt.target.value});
};render = () => {
return
};
};
```## Available props
|prop|description|type|
|--|----|----|
|innerRef|element's [`ref` attribute](https://reactjs.org/docs/refs-and-the-dom.html)|Object \| Function|
|html|**required:** innerHTML of the editable element|String|
|disabled|use true to disable editing|Boolean|
|onChange|called whenever `innerHTML` changes|Function|
|onBlur|called whenever the html element is [blurred](https://developer.mozilla.org/en-US/docs/Web/Events/blur)|Function|
|onFocus|event fires when an element has received [focus](https://developer.mozilla.org/en-US/docs/Web/API/Element/focus_event)|Function|
|onKeyUp|called whenever a key is released|Function|
|onKeyDown|called whenever a key is pressed |Function|
|className|the element's [CSS class](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/class)|String|
|style|a collection of CSS properties to apply to the element|Object|## Known Issues
If you are using hooks, please see [this issue](https://github.com/lovasoa/react-contenteditable/issues/161). Using this component with [`useState`](https://reactjs.org/docs/hooks-reference.html#usestate) doesn't work, but you can still use [`useRef`](https://reactjs.org/docs/hooks-reference.html#useref) :```js
const text = useRef('');const handleChange = evt => {
text.current = evt.target.value;
};const handleBlur = () => {
console.log(text.current);
};return
```## Examples
You can try **react-contenteditable** right from your browser to see if it fits your project's needs:
* [Simple example](https://codesandbox.io/s/4rlw34mnk7) : just an editable `
` with a default value.
* [Advanced example](https://codesandbox.io/s/l91xvkox9l) : custom tag, input sanitization, and rich text edition.