首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从函数中导出变量

从函数中导出变量
EN

Stack Overflow用户
提问于 2020-09-09 08:55:18
回答 1查看 51关注 0票数 0

如何从主题组件导出isDark?或者可以在不导出的情况下从另一个文件中查询isDark

Toggle.js

代码语言:javascript
复制
import React, { Component, useEffect } from "react";
import { Particles as ReactParticles } from 'react-particles-js';
import usePersistentState from '../hooks/PersistentState';

const Theme = () => {
    const [isDark, setIsDark] = usePersistentState('theme', true); // default to dark mode

    useEffect(() => {
        if (isDark) {
            document.documentElement.classList.add('other');
        } else {
            document.documentElement.classList.remove('other');
        }
    });

    return (
        <div>
            <main>
                <input id="toggle" name="toggle" type="checkbox" checked={isDark} onChange={event => setIsDark(event.target.checked)} />
                <label htmlFor="toggle" className="switch" id="switch"></label>
            </main>
        </div>
    )
}

class Toggle extends Component {
    render() {
        return (
            <Theme />
        );
    }
}

export default Toggle;

我正在尝试使用isDarkBackground.js

代码语言:javascript
复制
import React, { Component } from 'react';
import { isDark } from './Toggle' <- doesnt work obviously
console.log(isDark)

const PARAMS = {
    "text": {
        "color": {
            "value": `${isDark ? '#000000' : '#FFFFFF'}`
        },
        ...

其中使用了PARAMS

代码语言:javascript
复制
class Background extends Component {
    render() {
        return (
            <div className="particles">
                <ReactParticles width='100vw' height="100vh" params={PARAMS} />
            </div>
        )
    }
}
EN

回答 1

Stack Overflow用户

发布于 2020-09-09 08:59:40

使用钩子。将其命名为类似于useTheme的名称,并让它返回读取的主题值。您还可以考虑使用上下文,以便可以在上下文提供程序中缓存主题值。

Here就是一个例子。您可以看到,我创建了一个上下文值,该值可以保持单个主题实例,稍后可以通过useTheme注入该实例。您可以向上下文对象添加任何您想要的内容,并允许钩子有选择地将这些值导出到消费者。这很好,因为钩子可以接受一堆冗长的值和设置器,并为消费者提供更符合人体工程学的api。这就是react-redux和react-router的工作方式。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63803330

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档