最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

详细解读在React组件“外”如何使用父组件

来源:动视网 责编:小采 时间:2020-11-27 19:37:56
文档

详细解读在React组件“外”如何使用父组件

详细解读在React组件外如何使用父组件:这篇文章主要介绍了详解如何在React组件外使用父组件的Props,现在分享给大家,也给大家做个参考。在写SDK项目的时候碰到一个问题:在直播间初始化SDK时使用默认主题,在专题页初始化SDK时使用其它主题。默认主题在打包时挂在全局环境下供多个页面使用,
推荐度:
导读详细解读在React组件外如何使用父组件:这篇文章主要介绍了详解如何在React组件外使用父组件的Props,现在分享给大家,也给大家做个参考。在写SDK项目的时候碰到一个问题:在直播间初始化SDK时使用默认主题,在专题页初始化SDK时使用其它主题。默认主题在打包时挂在全局环境下供多个页面使用,


这篇文章主要介绍了详解如何在React组件“外”使用父组件的Props,现在分享给大家,也给大家做个参考。

在写SDK项目的时候碰到一个问题:在直播间初始化SDK时使用默认主题,在专题页初始化SDK时使用其它主题。默认主题在打包时挂在全局环境下供多个页面使用,定制主题需要在初始化SDK的时候传入。

实现起来很简单,判断是否有定制主题,有就使用定制主题,没有就使用默认主题。项目下的基本组件大多是这样的:

import { h, Component } from 'lib/preact'
import csjs from 'lib/csjs'
import { theme } from 'lib/platform'

const styles = csjs`
 .app {
 background: ${theme.color};
 }
`

export default class App extends Component {
 render(
 <p className='styles.app'></p>
 )
}

定制主题是通过初始化SDK传进来的,子组件可以通过props或者context拿到,但是却不能在class外的styles里面直接使用。

那么如何实现在组件“外”使用父组件的Props呢?如果我们可以把需要使用的Props挂在“全局环境”下,那么不就可以随便使用了吗?

项目结构如下:

.
|——src
| |——lib //公用库
| |——services //抽离出的方法
| |——index.js
| └──App
| └──app.js
└── ...

首先,在services中新建一个customTheme.js文件,内容如下:

let value = {}

export default () => {

 const setTheme = (initColor) => {
 value = initColor
 }

 const getTheme = () => {
 return value
 }

 return {
 setTheme,
 getTheme,
 }
}

在index.js文件中我们可以拿到初始化SDK时传入的定制主题对象,这里我们把这个对象存储到customTheme.js里的value中:

import customTheme from './services/customTheme'

...

const setTheme = (customTheme() || {}).setTheme
setTheme && setTheme(customTheme)

...

这样就可以在其它地方直接拿到customTheme的值了

import { h, Component } from 'lib/preact'
import csjs from 'lib/csjs'
import { theme } from 'lib/platform'
import customTheme from '../services/customTheme'
const getTheme = (customTheme() || {}).getTheme
const custom_theme = getTheme && getTheme()
const styles = csjs`
 .app {
 background: ${custom_theme.color || theme.color};
 }
`
export default class App extends Component {
 render(
 <p className='styles.app'></p>
 )
}

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在VUE中引用 bmob js-sdk(详细教程)

在vue中如何通过v-for处理数组

使用vue如何实现收藏夹

在node.js中有关npm和webpack配置方法

如何通过js将当前时间格式化?

文档

详细解读在React组件“外”如何使用父组件

详细解读在React组件外如何使用父组件:这篇文章主要介绍了详解如何在React组件外使用父组件的Props,现在分享给大家,也给大家做个参考。在写SDK项目的时候碰到一个问题:在直播间初始化SDK时使用默认主题,在专题页初始化SDK时使用其它主题。默认主题在打包时挂在全局环境下供多个页面使用,
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top