Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/calebdwilliams/jsx-native-events
A JSX schema for adding support for native events (including CustomEvent)
https://github.com/calebdwilliams/jsx-native-events
jsx jsx-pragma native-events native-jsx-events react web-components
Last synced: 3 months ago
JSON representation
A JSX schema for adding support for native events (including CustomEvent)
- Host: GitHub
- URL: https://github.com/calebdwilliams/jsx-native-events
- Owner: calebdwilliams
- License: other
- Created: 2019-06-15T18:14:42.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-02-12T02:08:41.000Z (almost 3 years ago)
- Last Synced: 2024-04-14T04:01:06.704Z (9 months ago)
- Topics: jsx, jsx-pragma, native-events, native-jsx-events, react, web-components
- Language: JavaScript
- Size: 1.82 MB
- Stars: 37
- Watchers: 2
- Forks: 4
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# jsx-native-events
[![Travis][build-badge]][build]
[![npm package][npm-badge]][npm]
[![Coveralls][coveralls-badge]][coveralls]This module adds a custom JSX pragma enabling native DOM events to be handled declaratively in JSX. In traditional JSX, events need to be handled by passing down props to elements such as `onClick` or `onChange` that will be attached to the compiled DOM element at some point during the application's lifecycle. For standard events, this works great; however, for events that aren't as common or for [constructed events](https://developer.mozilla.org/en-US/docs/Web/Guide/Events/Creating_and_triggering_events) or instances of [CustomEvent](https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent/CustomEvent), the prop API falls short.
This JSX pragma allows users to declaratively attach event listeners to elements using the `onEvent` syntax where `` would be replaced by a [camelCase](https://en.wikipedia.org/wiki/Camel_case) version of the event's name. So, a `'click'` event would use the prop `onEventClick` or a custom event with a name of `accordion-toggle` would use the `onEventAccordionToggle` prop.
## Why onEvent?
The use of `onEvent`, though a bit verbose, was intentional to minimize conflicts with existing code in the React ecosystem while still keeping the syntax familiar. Using `on` would require double checking for the native JSX events. Likewise, using syntax such as `on-accordion-toggle` would feel foreign to existing JSX codebases. The `onEvent` prefix seemed like the best option in the short term.
## Installing
The recommended installation method of this package is through [npm](http://npmjs.com). If you are unfamiliar with the npm ecosystem, there is some great [documentation available on the npm website](https://docs.npmjs.com/cli/install).
If you are familiar with npm, you can install this package using the command
`npm i -D jsx-native-events`
## Usage
### [See this example on StackBlitz](https://stackblitz.com/edit/jsx-native-events-demo)
Because the primary output of this package is a JSX pragma, you will first need to include the `/** @jsx */` syntax in your file.
Or add `pragma: "nativeEvents"` to your [`@babel/preset-react`](https://babeljs.io/docs/en/babel-preset-react) or [`@babel/plugin-transform-react-jsx`](https://babeljs.io/docs/en/babel-plugin-transform-react-jsx) babel config.
```jsx
/** @jsx nativeEvents */
import React, { useState } from 'react'
import nativeEvents from 'jsx-native-events'export default function SomeComponent (props) {
const [ name, setName ] = useState('')
return
My name is {name}
setName(e.detail) }>
}
```In the above example, `` is an example of a [custom element](https://css-tricks.com/an-introduction-to-web-components/) that dispatches an event called `custom-event`. In our React application, we want to listen for that custom event and set the name every time the event is emitted.
Using the `/** @jsx nativeEvents */` pragma at the top of the file lets JSX know that we want to use the function imported in line 3 (`import nativeEvents from 'jsx-native-events'`) as an addition to React's built-in JSX engine.
The new props will only work for implementations of [`EventTarget`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget), so the new props are not ignored on React components, but should work on all DOM elements represented by React's JSX.
[build-badge]: https://img.shields.io/travis/user/repo/master.png?style=flat-square
[build]: https://travis-ci.org/user/repo[npm-badge]: https://img.shields.io/npm/v/npm-package.png?style=flat-square
[npm]: https://www.npmjs.org/package/npm-package[coveralls-badge]: https://img.shields.io/coveralls/user/repo/master.png?style=flat-square
[coveralls]: https://coveralls.io/github/user/repo