react-clone-tree
v1.1.0
Published
Clone React Element Tree, allow you change props for each tree element, and replace children.
Downloads
3
Readme
react-clone-tree
Clone React Element Tree, allow you change props for each tree element, and replace children.
Install
npm install react-clone-tree
# or
yarn add react-clone-tree
Usage
import React from 'react'
import clone from 'react-clone-tree'
const replacer = str => (str && {className: 'my-prefix-' + str})
const newThing = clone(
<div className="a"><p className="b"><span>text</span></p></div>,
el => replacer(el.props.className)
)
The newThing
will be:
<div className="my-prefix-a"><p className="my-prefix-b"><span>text</span></p></div>
The API is easy:
// clone(JSX, [replacer])
var newJSX = clone(JSX, el => new_props_for_this_el)
If you return { children: <Foo/> }
from above replacer
, the children elements will be replaced.
The return_val
of replacer
will be passed into Object.assign({}, return_val)
, so if you return Non-Object
, nothing happend.