码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • npm run dev和npm run serve


    npm run dev和npm run serve

    • 目录
      • 概述
        • 需求:
      • 设计思路
      • 实现思路分析
        • 1.npm install命令
        • 2.package.json
        • 3.npm run serve
    • 参考资料和推荐阅读

    Survive by day and develop by night.
    talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
    happy for hardess to solve denpendies.

    目录

    在这里插入图片描述

    概述

    npm run dev和npm run serve的是一个非常常见的需求。

    需求:

    npm实际上是nodejs官方提供的包管理平台,npm提供了一个命令行工具npm-cli,在我们使用npm这个命令时,我们实际是通过node运行一个名为npm-cli.js的脚本

    设计思路

    实现思路分析

    1.npm install命令

    在构建项目时,通过npm install命令,会在项目目录下生成一个名为node_modules的文件夹

    2.package.json

    在package.json文件中,有一个scripts的字段

    // 运行npm run serve的scripts字段
      "scripts": {
        "serve": "vue-cli-service serve",
        "build": "vue-cli-service build",
        "lint": "vue-cli-service lint"
      },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    //运行npm run dev的scripts字段
    "scripts": {
        "dev": "vue-cli-service serve",
        "build": "vue-cli-service build",
        "lint": "vue-cli-service lint",
        "webpack": "webpack --version"
      },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    3.npm run serve

    npm run serve的时候是运行vue-cli-service serv
    node_modules文件夹的.bin文件

    然不能直接运行vue-cli-service,但是我们在npm run的时候,会前往node_modules/.bin下找到vue-cli-service文件,然后将该文件作为脚本运行。

    #!/bin/sh
    basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
    
    case `uname` in
        *CYGWIN*) basedir=`cygpath -w "$basedir"`;;
    esac
    
    if [ -x "$basedir/node" ]; then
      "$basedir/node"  "$basedir/../@vue/cli-service/bin/vue-cli-service.js" "$@"
      ret=$?
    else 
      node  "$basedir/../@vue/cli-service/bin/vue-cli-service.js" "$@"
      ret=$?
    fi
    exit $ret
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    @IF EXIST "%~dp0\node.exe" (
      "%~dp0\node.exe"  "%~dp0\..\@vue\cli-service\bin\vue-cli-service.js" %*
    ) ELSE (
      @SETLOCAL
      @SET PATHEXT=%PATHEXT:;.JS;=;%
      node  "%~dp0\..\@vue\cli-service\bin\vue-cli-service.js" %*
    )
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    参考资料和推荐阅读

    [1]. https://juejin.cn/post/7139045537864482853

    欢迎阅读,各位老铁,如果对你有帮助,点个赞加个关注呗!~

  • 相关阅读:
    Microsoft VBA Excel 去重+自动化配对信息
    Spring AOP基于XML方式笔记整理
    shell脚本的文本处理工具
    opencv图像像素类型转换与归一化
    Spring Cloud Gateway从数据库读取并更新Cors配置
    RIP,EIGRP,OSPF区别
    C/C++面经嵌入式面经软件开发面经<28/30>-- 单片机相关(一)
    前端发展趋势:WebAssembly、PWA 和响应式设计
    UI 自动化测试框架设计与 PageObject 改造!
    Ruoyi若依前后端一体项目整合cas单点登录
  • 原文地址:https://blog.csdn.net/xiamaocheng/article/details/128164565
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号