New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

react-any-attr

Package Overview
Dependencies
Maintainers
1
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-any-attr

Enables you to create any HTML attribute in React spearing the headache.

latest
Source
npmnpm
Version
1.1.2
Version published
Maintainers
1
Created
Source

react-any-attr

Coverage Status License Rate on Openbase

From time to time you might have the need to add a custom attribute to an HTML element and React won't let you. It is not very common situation, but when it presents itself you must do things not the REACT WAY. This is the purpose of this package. it assists adding any attribute to any HTML element in React environment. The package provides a component called AnyAttribute that wraps any HTML elements you wish to add any attribute to.

Installation

$ npm install react-any-attr

Usage

import AnyAttribute, { asObject, asString } from 'react-any-attr';

The component receives one property called attributes. This property defines the attributes to add to any HTML element it wraps directly. The component also provides two helper functions called asObject and asString.

asString

Adds anything to an element converted to string. The attribute will be added to the "outerHTML" of the element and will be visible in the developer tools. note that any attribute name will convert to lowercase.

asObject

Adds anything to an element without any convertions. The attribute will not be added to the "outerHTML" of the element and will not be visible in the inspect. note that these attributes will keep their camelCase format.

You can avoid using the asObject and asString functions at all. Just be aware of the implications.

Example

<AnyAttribute
    attributes={{
        objectTimestamp: asObject((new Date()).valueOf()),
        stringTimestamp: asString((new Date()).valueOf()),
        objectAsString : asString({data: myDataObject}),
        objectAsObject : asObject({data: myDataObject}),
        objectAsIs: myDataObject,
        anythingElse: 'Hello darkness my old friend...'
    }}>
    <input id={"input"} />
</AnyAttribute>

The result

Note that any attribute set with asObject are not visible, and any attribute set with asString are visible and the attribute name is in lowercase.

<input id="input" stringtimestamp="158970528706" objectasstring="{"data":{"name":"Your Name", "age": 120, "pet": "cat"}}" objectasis="[object Object]" anythingelse="Hello darkness my old friend...">

Note: From version 1.1 useRef is supported. String ref is not supported and WILL NOT WORK because it's deprecated!!!

Have a good productive day :)

If you like this package please consider donation Click Here

Keywords

React

FAQs

Package last updated on 15 Dec 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts