zoukankan      html  css  js  c++  java
  • yalc: 开发前端插件&组件比npm link 更好用

    使用场景

    1.在组件和插件依赖开发中,项目作为依赖库没办法单独直接运行,需要依赖进别的项目执行,这时候最常用的方式就是npm link。但用npm link引入的依赖由于资源文件不在项目下webpack不会对其做预编译,导致实际构建或者运行时会报错,此时如果直接将文件复制进依赖目录则能正常运行,yalc能解决此类问题。

    2.在一个项目中,我们会用 HRM 热更新来让我们修改的代码在浏览器中快速看到效果,快速验证我们的代码是否正确。

    当项目开始变大,为了提效、跨项目复用,我们会不可避免的需要开始去拆分一些通用的 NPM 模块

    yalc工作流程图 

    Yalc

    yalc 可以在本地将npm包模拟发布,将发布后的资源存放在一个全局存储中。然后可以通过yalc将包添加进需要引用的项目中。

    这时候package.json的依赖表中会多出一个file:.yalc/...的依赖包,这就是yalc创建的特殊引用。同时也会在项目根目录创建一个yalc.lock确保引用资源的一致性。因此,测试完项目还需要执行删除yalc包的操作,才能正常使用。

    整个过程相对于npm link会更加繁琐一些,要经过发包、添加依赖,结束后也需要做清除操作,但也正因此才避免了npm link的一些问题。

    安装

    NPM:
    npm i yalc -g
    
    Yarn:
    yarn global add yalc
    

      

    发布依赖

    在所开发的依赖项目下执行发布操作

    yalc publish
    

      

    此时如果存在npm 生命周期脚本:prepublishprepareprepublishOnlyprepackpreyalcpublish,会按此顺序逐一执行。如果存在:postyalcpublishpostpackpublishpostpublish,也会按此顺序逐一执行。

    想要完全禁用脚本执行需要使用

    yalc publish --no-scripts
    

      

    此时就已经将依赖发布到本地仓库了。

    当有新修改的包需要发布时,使用推送命令可以快速的更新所有依赖

    yalc publish --push
    yalc push // 简写
    

      

    参数:

    • --changed,快速检查文件是否被更改
    • --replace,强制替换包

    添加依赖

    进入到项目执行

    yalc add [my-package]
    

      

    可以看到项目中添加了yalc.lock文件,package.json对应的包名会有个地址为file:.yalc/开头的项目。
    也可以使用

    yalc add [my-package@version]
    

      

    将版本锁定,避免因为本地新包推送产生影响。

    参数:

    • --dev,将依赖添加进dependency
    • --pure,不会影响package.json文件
    • --link,使用link方式引用依赖包,yalc add [my-package] --link
    • --workspace (or -W),添加依赖到workspace:协议中

    更新依赖

    yalc update
    yalc update [my-package]
    

      

    会根据yalc.lock查找更新所有依赖

    移除依赖

    yalc remove [my-package]
    
    yalc remove --all // 移除所有依赖并还原
    

      

    查看仓库信息

    当我们要查看本地仓库里存在的包时

    yalc installations show
    

      

    要清理不需要的包时

     
    yalc installations clean [my-package]
    

     

  • 相关阅读:
    写了一个好玩的小软件, 监视鼠标以及键盘的动作, 全局钩子. HowTired
    2005的五一计划
    给你的爱一直很安静
    沉重悼念蓝色理想经典论坛原Flash版主[手工感情][Handmade]
    一不小心就成就了一段姻缘,哈哈
    基于dotnet的代码统计工具新版发布
    四天三夜 刻骨铭心 颠峰战将 永不言败
    怎么回事?现在博客园极不稳定
    屋漏偏逢连夜雨, 船迟又遇打头风
    适用于IE浏览器及非IE浏览器的xmlhttp脚本
  • 原文地址:https://www.cnblogs.com/ygunoil/p/14870542.html
Copyright © 2011-2022 走看看