码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • react代码编译+部署完成,运行前:如何修改配置文件以改变代码中对应变量的值?


    最后更新于2022年8月9日 11:23:54:

    使用create react app构建项目

    方法一:

    写在config.json中,直接import。这种方法借用了一个第三方库,具体名字忘记了,问题在于webpack在编译时会把config.json也编译进项目中,运行时根本无法修改。

    说人话就是npm run build完了,你配置写的啥样,那就是啥样了。比如说你在config.json里面写的server_ip=123.123.123.123,那他运行起来就这样了,想改只能返回源码里面改好了再编译一遍,那有个屁用啊,还不如直接写代码里。

    方法二:

    create react app自带motdotla/dotenv库,可以手动在项目根目录下创建一个config.env文件,里头写上你想要的参数,比如REACT_APP_SERVER_IP=123.123.123.123。这样在代码里面用process.env.REACT_APP_SERVER_IP调用即可。

    跟方法一差不多,有屁用啊?参见:How to implement runtime environment variables with create-react-app, Docker, and Nginx
    It can’t inject environment variables during content serving (like Next.js does). During transpiling, Webpack process replaces all occurrences of process.env with a string value that was given. This means it can only be configured during build time.

    方法三:

    直接fetch本地的config.json文件,代码如下:

    const configFetch = async (path) => {
        try {
            const response = await fetch(path);
            const respJson = await response.json();
            return respJson;
        } catch (e) {
            console.log(e);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    试过了,问题在于fetch是异步的,用起来嘿,那叫一个恶心。

    方法四:

    创建config.js到public目录下,在index.html目录中调用。参见

    看作者是个印度小姐姐,说的信誓旦旦的,长得又好看,相信她吧。下面的回复说这样会造成安全隐患?

    在react项目中做公共配置文件,这里说的更详细,而且是中文的,但是这篇文章里面的第四步我没有做,做完前三步就可以用window.config.XXX调到变量了。

  • 相关阅读:
    vscode搭建LVGL开发环境
    查分小程序,教学大作用
    Kernel Memory 入门系列:文档的管理
    十五、Django之编辑员工和删除员工
    从无到有跑通KAPAO
    七个研究生必备高效科研网站
    如何提升软件测试效率?本文为你揭示秘密
    【【STM32-29正点原子版本串口发送传输实验】
    拿下跨界C1轮投资,本土Tier 1高阶智能驾驶系统迅速“出圈”
    5_会话管理实现登录功能
  • 原文地址:https://blog.csdn.net/weixin_44445507/article/details/126244267
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号