React 非父子組件傳參的實(shí)例代碼
React 是一個(gè)用于構(gòu)建用戶界面的 JAVASCRIPT 庫。
React 主要用于構(gòu)建UI,很多人認(rèn)為 React 是 MVC 中的 V(視圖)。
React 起源于 Facebook 的內(nèi)部項(xiàng)目,用來架設(shè) Instagram 的網(wǎng)站,并于 2013 年 5 月開源。
React 擁有較高的性能,代碼邏輯非常簡單,越來越多的人已開始關(guān)注和使用它。
React 特點(diǎn)
1.聲明式設(shè)計(jì) −React采用聲明范式,可以輕松描述應(yīng)用。
2.高效 −React通過對(duì)DOM的模擬,最大限度地減少與DOM的交互。
3.靈活 −React可以與已知的庫或框架很好地配合。
4.JSX − JSX 是 JavaScript 語法的擴(kuò)展。React 開發(fā)不一定使用 JSX ,但我們建議使用它。
5.組件 − 通過 React 構(gòu)建組件,使得代碼更加容易得到復(fù)用,能夠很好的應(yīng)用在大項(xiàng)目的開發(fā)中。
6.單向響應(yīng)的數(shù)據(jù)流 − React 實(shí)現(xiàn)了單向響應(yīng)的數(shù)據(jù)流,從而減少了重復(fù)代碼,這也是它為什么比傳統(tǒng)數(shù)據(jù)綁定更簡單。
下面給大家介紹React 非父子組件傳參的實(shí)例代碼,具體內(nèi)容如下:
新版:跨級(jí)傳參最主要是避免每層賦值,也避免用到dva
import React from 'react'
const {Provider,Consumer} = React.createContext('default')
export default class ContextDemo extends React.Component {
state={
newContext:'createContext'
}
render() {
const {newContext} = this.state
return (
<Provider value={newContext}>
<div>
<label>childContent</label>
<input type="text" value={newContext} onChange={e=>this.setState({newContext:e.target.value})}/>
</div>
<Son />
</Provider>
)
}
}
class Son extends React.Component{
render(){
return <Consumer>
{
(name)=>
<div style={{border:'1px solid red',width:'60%',margin:'20px auto',textAlign:'center'}}>
<p>子組件獲取到的內(nèi)容:{name}</p>
<Grandson />
</div>
}
</Consumer>
}
}
class Grandson extends React.Component{
render(){
return <Consumer>
{
(name)=>
<div style={{border:'1px solid red',width:'60%',margin:'20px auto',textAlign:'center'}}>
<p>孫子組件獲取到的內(nèi)容:{name}</p>
</div>
}
</Consumer>
}
}
老項(xiàng)目的方式也介紹一下,利用prop-types
import React from 'react'
import PropTypes from 'prop-types'
class ContextDemo extends React.Component {
// getChildContext
state={
newContext:'createContext'
}
getChildContext(){
return {value:this.state.newContext}
}
render() {
const {newContext} = this.state
return (
<div>
<div>
<label>childContent</label>
<input type="text" value={newContext} onChange={e=>this.setState({newContext:e.target.value})}/>
</div>
<Son />
</div>
)
}
}
class Son extends React.Component{
render(){
return <div>
<p>children:{this.context.value}</p>
</div>
}
}
Son.contextTypes = {
value:PropTypes.string
}
ContextDemo.childContextTypes = {
value:PropTypes.string
}
export default () =>
<ContextDemo >
</ContextDemo>
ref
import React from 'react'
// 函數(shù)組件也想拿到dom 通過 ref
const TargetFunction = React.forwardRef((props,ref)=>(
<input type="text" ref={ref}/>
))
export default class FrodWordRefDemo extends React.Component {
constructor() {
super()
this.ref = React.createRef()
}
componentDidMount() {
this.ref.current.value = 'ref get input'
}
render() {
return <TargetFunction ref={this.ref}>
</TargetFunction>
}
}
pubsub-js
import React from 'react'
import PubSub from 'pubsub-js'
export default class Bro extends React.Component{
state = {
value:''
}
render(){
const {value} = this.state
PubSub.subscribe('SOS',(res,data)=>{
this.setState({
value:data
})
})
return (
<div>
我接受到了
<h1>{value}</h1>
</div>
)
}
}
import React from 'react'
import PubSub from 'pubsub-js'
export default class Children extends React.Component{
state = {
value:''
}
handelChange = (e) =>{
this.setState({
value:e.target.value
})
}
send = () =>{
const {value} = this.state
PubSub.publish('SOS',value)
}
render(){
const {value} = this.state
return (
<div>
<input type="text" value={value} onChange={this.handelChange}/>
<button onClick={this.send}>發(fā)送</button>
</div>
)
}
}
到此這篇關(guān)于React 非父子組件傳參的實(shí)例代碼的文章就介紹到這了,更多相關(guān)React 非父子組件傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React css-in-js基礎(chǔ)介紹與應(yīng)用
隨著React、Vue等支持組件化的MVVM前端框架越來越流行,在js中直接編寫css的技術(shù)方案也越來越被大家所接受。為什么前端開發(fā)者們更青睞于這些css-in-js的方案呢,下面帶你了解它2022-09-09
React合成事件及Test Utilities在Facebook內(nèi)部進(jìn)行測(cè)試
這篇文章主要介紹了React合成事件及Test Utilities在Facebook內(nèi)部進(jìn)行測(cè)試,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
react使用axios進(jìn)行api網(wǎng)絡(luò)請(qǐng)求的封裝方法詳解
這篇文章主要為大家詳細(xì)介紹了react使用axios進(jìn)行api網(wǎng)絡(luò)請(qǐng)求的封裝方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
更強(qiáng)大的React 狀態(tài)管理庫Zustand使用詳解
這篇文章主要為大家介紹了更強(qiáng)大的React 狀態(tài)管理庫Zustand使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
詳解使用WebPack搭建React開發(fā)環(huán)境
這篇文章主要介紹了詳解使用WebPack搭建React開發(fā)環(huán)境,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
React?Hook中的useState函數(shù)的詳細(xì)解析
Hook 就是 JavaScript 函數(shù),這個(gè)函數(shù)可以幫助你鉤入(hook into) React State以及生命周期等特性,這篇文章主要介紹了React?Hook?useState函數(shù)的詳細(xì)解析的相關(guān)資料,需要的朋友可以參考下2022-10-10

