最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 如何做到修改了node_module中的包,却不受重新安装的影响

    正文概述 掘金(KDDA_)   2021-04-27   854

    背景

    前言

    修改别人的源码往往有这几个方式:

    1. 直接在项目的node_modules下找到插件的源码直接修改;
      • 优点:简单直接、快速见效
      • 缺点:不能持久化,一旦重新安装就失效;不方便团队成员使用修改后的代码
    2. 去github上fork代码到自己的仓库进行修改,并将自己修改过后的代码发布到npm上使用;
      • 优点:团队成员都可以使用到这份修改的代码
      • 缺点:麻烦、十分麻烦

    显而易见,上面这两种方法既不优雅,也不可靠。作为程序员的我们岂能被这事儿给难住,开源社区早已给我们准备好了解决方案:patch-package

    使用补丁

    通过cra开启一个项目

    npx create-react-app my-app
    cd my-app
    npm start
    

    给项目@alifd/next(ui库)、patch-package、postinstall-postinstall(使用yarn安装时需要安装,npm无需安装此依赖)

    yarn add @alifd/next patch-package postinstall-postinstall -D
    

    给 package.json文件中添加脚本命令(非常重要

     "scripts": {
    +  "postinstall": "patch-package"
     }
    

    我们引入组件button,并查看组件当前结构

    如何做到修改了node_module中的包,却不受重新安装的影响

    我们去node_module中修改button源码

    如何做到修改了node_module中的包,却不受重新安装的影响

    我们在看看页面情况(如果没有效果的话,可以重启一下服务 )

    如何做到修改了node_module中的包,却不受重新安装的影响

    修改完并且也生效了,我们就要开始打补丁了,运行命令yarn patch-package package-name

    yarn patch-package @alifd/next
    

    成功后你会看到根目录多了一个patches文件夹,里面包含了你修改的npm包的patch文件。点开可以很清楚的看到你都做了哪些修改

    如何做到修改了node_module中的包,却不受重新安装的影响

    测试

    删除node_module并重新安装

    rm -rf node_modules/ && yarn
    

    依赖包安装时候可以在命令行中看到补丁的应用

    yarn install v1.22.4
    [1/4] ?  Resolving packages...
    [2/4] ?  Fetching packages...
    [3/4] ?  Linking dependencies...
    warning " > @testing-library/user-event@12.8.3" has unmet peer dependency "@testing-library/dom@>=7.21.4".
    warning "react-scripts > @typescript-eslint/eslint-plugin > tsutils@3.21.0" has unmet peer dependency "typescript@>=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta".
    warning " > @alifd/next@1.22.21" has unmet peer dependency "@alifd/meet-react@^2.0.0".
    warning " > @alifd/next@1.22.21" has unmet peer dependency "moment@^2.22.1".
    warning " > @alifd/next@1.22.21" has incorrect peer dependency "react@^16.0.0".
    warning " > @alifd/next@1.22.21" has incorrect peer dependency "react-dom@^16.0.0".
    [4/4] ?  Building fresh packages...
    $ patch-package
    patch-package 6.4.7
    Applying patches...
    @alifd/next@1.22.21 ✔
    ✨  Done in 20.10s.
    

    yarn start重新启动,查看审查元素,依旧是a标签!

    结束

    这篇文章非常的简短,但是实用性非常高,如果这篇文章给了你启发或帮助,那就点个赞吧!?


    起源地下载网 » 如何做到修改了node_module中的包,却不受重新安装的影响

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元