Skip to content
This repository has been archived by the owner on Jun 15, 2021. It is now read-only.

bitionaire/react-id-decorator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

README

If your React components should be reusable you may not set the id attribute within the HTML elements of your JSX. If you would like to use a combination of e.g. <label for="..."/><input id="..."/> you will need to generate globally unique identifiers before render() will be called. This module tries to solve the need for any repetitive implementation.

Installation

npm install --save react-id-decorator

Usage

You can call Decorate.id(...strings) with an array of strings (e.g. names of your elements) you want to create identifiers for. The props of the decorated component will be extended by the id dictionary you may use to retrieve the generated unique identifiers.

So if you have a component like this ...

import * as React from 'react';

class YourComponent extends React.Component {
    render() {
        return (
            <div>
                <label></label>
                <input type="text"/>
            </div>
        )
    }
}

... and you want to generate a unique id, just use ...

import * as React from 'react';
import { Decorate } from 'react-id-decorator';

@Decorate.id("elementGroup")
class YourComponent extends React.Component {
    render() {
        const { id } = this.props;

        return (
            <div>
                <label htmlFor={id["elementGroup"]}></label>
                <input id={id["elementGroup"]} type="text"/>
            </div>
        )
    }
}

About

Unique id decorator for React components

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published