zoukankan      html  css  js  c++  java
  • 前端移动node_modules到其他位置

    说明

    现在前端开发都是工程化管理, npm、yarn等包管理工具会在源码目录下生产node_modules文件夹;
    node_modules文件夹很庞大, 文件数量很多, 有时候希望移动到其他位置, 这里提供一种方法;

    原理

    创建node_modules、package.json和其他的配置文件(如postcss.config.js)的符号链接(symbolic link)

    批处理脚本

    命名为mknm.bat放到path路径, 在前端源码根目录执行mknm

    @rem 作用:在传入的文件夹下创建一个node_modules的link
    @rem 用法: 参数: 一个文件夹的完整路径, 如果忽略使用当前目录;
    @rem 其他:
    @rem 2018/11/08 周四 15:32:59.03
    @echo off&SetLocal EnableDelayEdexpansion
    
    rem 传入一个文件夹路径
    if "%1" equ "" (
      "%~0" "%cd%"
      goto :eof
    )
    echo 当前路径: %cd%
    echo;
    
    rem 1. 传入一个文件夹的路径; 2. 在baseDir创建同名的文件夹; 3. 创建link
    set dirPath=%~1
    set dirName=%~nx1
    set baseDir=D:\_node_modules
    
    if not defined dirPath (
      echo 参数为空; 应该传入路径
      pause&goto :eof
    )
    rem 创建文件夹; 最终的文件夹的路径是newDir
    call :creatDir "!dirName!"
    
    mklink /d "!dirPath!
    ode_modules" "!newDir!
    ode_modules"
    mklink "!newDir!package.json" "!dirPath!package.json"
    if exist "!dirPath!postcss.config.js" (
      mklink "!newDir!postcss.config.js" "!dirPath!postcss.config.js"
    )
    
    
    set file="!newDir!
    eadme.txt"
    (
    echo mklink /d  "!dirPath!
    ode_modules" "!newDir!
    ode_modules"
    
    echo mklink "!newDir!package.json" "!dirPath!package.json"
    
    echo mklink "!newDir!postcss.config.js" "!dirPath!postcss.config.js"
    
    ) >%file%
    
    
    echo 完成..........
    goto :eof
    
    
    :creatDir
    set "name=%~1"
    :A
    set newDir=!baseDir!!name!
    if not exist "!newDir!" (
      mkdir "!newDir!
    ode_modules"
      goto :eof
    ) else (
      set "name=!name!-1"
      goto :A
    )
    
    :eof
    

    注意

    不保证100%有效, 可能install出错、运行出错, 可以尝试把其他文件(比如vue.config.js)也link一下;

  • 相关阅读:
    使用C#直接修改表结构(添加列,删除列)【MS SQL SEVER】
    Nuget-ConsoleExtClass给控制台添加颜色
    Thread线程Join()的使用
    C#将List集合类转换成DataTable-帮助类
    C#动态拼接Linq
    C#使用AutoMapper
    go GOPROXY=http://goproxy.io 设置
    mysql5.6切到5.7(阿里云RDS换到自建库)
    vue学习之----如何在谷歌浏览器中使用vue调试工具
    vue学习之----兄弟组件之间通信方式
  • 原文地址:https://www.cnblogs.com/QIAOXINGXING001/p/15543914.html
Copyright © 2011-2022 走看看