【Vue】七、Vue-cli工程化开发

news2024/11/17 17:30:47

后端程序员的vue学习之路

  • 一、 Vue-cli
    • 安装Vue-cli
    • 1、安装node.js
    • 2、配置node.js环境变量
    • 3、 Npm仓库设置淘宝源
    • 4、全局安装 vue-cli
    • 5、创建vue应用程序
      • 1、 创建vue项目基础骨架:
      • 2、 运行项目:
    • 6、vue项目结构
  • 二、Vue.js项目运行逻辑分析
    • 1、 npm run dev命令
    • 2、webpack.dev.conf.js
    • 3、config/index.js
    • 4、webpack.base.conf.js
    • 5、main.js
    • 6、找到自定义组件App.vue
    • 7、流程分析总结
    • 关闭 eslint的验证,在config/index.js文件

一、 Vue-cli

Vue-cli是Vue.js 提供一个官方命令行工具,帮我们快速生成项目的原型,可用于快速搭建大型单页应用;

安装Vue-cli

1、安装node.js

下载:http://nodejs.cn/download/
最新的版本,win7不能使用;
v12.16.2以上版本不支持win7系统,要下载v12.16.2及之前的版本即可;
安装:解压即完成安装;
检查安装后的效果:

node -v 
npm -v

新版的Node.js已自带npm,安装Node.js时就已经安装,npm的作用就是对Node.js依赖的包进行管理,可以理解为用来安装/卸载Node.js需要依赖的库;

2、配置node.js环境变量

1、在 自己的node安装目录下创建两个文件夹,例如我的D:\02_JavaSoftware\Node14.15.1下创建2个文件夹:

  • node_global (依赖库)
  • node_cache (缓存)

2、然后再当前目录下cmd进入dos窗口,执行:

npm config set prefix "D:\02_JavaSoftware\Node14.15.1\node_global" 
npm config set cache "D:\02_JavaSoftware\Node14.15.1\node_cache"

3、环境变量Path配置,在path变量中添加如下路径:

D:\02_JavaSoftware\Node14.15.1;D:\02_JavaSoftware\Node14.15.1\node_global;

4、在任意目录打开dos窗口测试下:

node -v
npm -v

5、安装一个模块(依赖库)测试一下看看:

npm install express -g  #其中-g是全局安装的意思

全局安装就会把express模块安装到;
D:\02_JavaSoftware\Node14.15.1\node_global目录下,否则就会安装到了当前执行命令所在的目录下:C:\Users\Administrator

  • express是一个快速,无缺陷,极简的Web框架;

3、 Npm仓库设置淘宝源

Npm仓库:https://www.npmjs.com/
查看目前的npm仓库源:

npm config get registry

在使用npm命令时,如果直接从国外的仓库https://www.npmjs.com/ 下载依赖,下载速度很慢,甚至会下载失败,我们可以更换npm的仓库源,提高下载速度,淘宝给我们提供了一个npm源;

//设置淘宝源
npm config set registry https://registry.npm.taobao.org

或者安装cnpm,以后用cnpm命令也可以
// 安装cnpm命令
npm install -g cnpm --registry=https://registry.npm.taobao.org

最后可在c盘usr目录下查看.npmrc文件内容如下
在这里插入图片描述

4、全局安装 vue-cli

$ npm install -g @vue/cli
$ npm i -g @vue/cli-init
如果安装失败可以先执行尝试清一下缓存:npm cache clean –force (清楚npm缓存)

5、创建vue应用程序

在这里插入图片描述

1、 创建vue项目基础骨架:

$ vue init webpack vue-project #这里需要进行一些配置,默认回车即可

其中vue-project是项目工程名称;
在这里插入图片描述
在这里插入图片描述

2、 运行项目:

进入项目,安装并运行:

$ cd vue-project
$ npm install
$ npm run dev

DONE Compiled successfully in 4388ms

Listening at http://localhost:8081
成功执行以上命令后访问 http://localhost:8081/ 输出结果;
在这里插入图片描述

6、vue项目结构

在这里插入图片描述

目录/文件说明
build项目构建(webpack)相关代码
config配置目录,包括端口号等;
node_modulesnpm 加载的项目依赖模块;
src这里是要开发的目录,基本上要做的事情都在这个目录里,包含了几个目录及文件:
assets: 放置一些图片,如logo等;
components: 目录里面放了一个组件文件,可以不用;
App.vue: 项目入口文件,我们也可以直接将组件写这里,而不使用 components 目录;
main.js: 项目的核心文件;
static静态资源目录,如图片、字体等;
test初始测试目录,可删除;
.xxxx文件这些是一些配置文件,包括语法配置,git配置等;
index.html首页入口文件,你可以添加一些 meta 信息或统计代码啥的;
package.json项目配置文件;
README.md项目的说明文档,markdown 格式;

根据模板生成的结构,其文档:
https://vuejs-templates.github.io/webpack/

二、Vue.js项目运行逻辑分析

1、 npm run dev命令

在这里插入图片描述

2、webpack.dev.conf.js

在这里插入图片描述

3、config/index.js

如果端口正在使用,则将确定一个空闲端口
因为我有启动一个后端项目,所以这个前端的使用了8081
在这里插入图片描述

4、webpack.base.conf.js

在这里插入图片描述

5、main.js

在这里插入图片描述

6、找到自定义组件App.vue

在这里插入图片描述

7、流程分析总结

  • 1、启动 npm run dev
scripts": {
"dev
  • 2、 执行webpack.dev.conf.js
build/webpack.dev.conf.js
  • 3、声明connfig下的静态js–配置端口
const config = require('../config') 
index.js --> 配置端口
  • 4、找到声明webpack.base.conf下的静态js-
const baseWebpackConfig = require('./webpack.base.conf')
  • 5、找到main.js
entry: {
    app: './src/main.js'
  },
  • 6、加载app组件在这里插入图片描述

关闭 eslint的验证,在config/index.js文件

module.exports = {
dev: {
useEslint: true,//改为false
}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/113325.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

3.11.2、虚拟局域网 VLAN 实现机制

虚拟局域网 VLAN 技术是在交换机上实现的,需要交换机能够实现以下两大功能 能够处理带有 VLAN 标记的帧:IEEE 802.1Q 帧交换机的各端口支持不同的端口类型(帧的处理方式有所不同) 1、IEEE 802.1Q 帧 IEEE 802.1Q 帧&#xff08…

Java项目:SpringBoot美容院预约管理系统

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本系统分为管理员与普通用户两种角色; 管理员角色包含以下功能: 登录,首页,新增管理员,管理员信息列表,网站用户信息列表…

node.js+uni计算机毕设项目基于微信小程序校园心理咨询(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

RabbitMQ 第一天 基础 1 MQ的基本概念 1.1 MQ 概述 1.2 MQ的优势和 劣势 1.3 MQ的优势

RabbitMQ 【黑马程序员RabbitMQ全套教程,rabbitmq消息中间件到实战】 文章目录RabbitMQ第一天 基础1 MQ的基本概念1.1 MQ 概述1.1.1 MQ 概述1.1.2 小结1.2 MQ的优势和 劣势1.2.1 概述1.3 MQ的优势1.3.1 应用解耦1.3.2 异步提速1.3.3 削峰填谷1.3.4 小结第一天 基础…

【SpringMVC】SpringMVC模型数据+视图解析器

目录 一、模型数据-如何将数据存入request域 二、模型数据-如何将数据存入session域 三、ModelAttribute 四、视图解析器 相关文章 【SpringMVC】入门篇:带你了解SpringMVC的执行流程【SpringMVC】入门篇:带你了解SpringMVC的执行流程 【SpringMVC】使用…

springboot整合swagger

特别说明:本次项目整合基于idea进行的,如果使用Eclipse可能操作会略有不同,不过总的来说不影响。 springboot整合之如何选择版本及项目搭建 springboot整合之版本号统一管理 springboot整合mybatis-plusdurid数据库连接池 springboot整合…

node.js+uni计算机毕设项目儿童健康成长档案小程序(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

暂时性死区以及函数作用域

暂时性死区 暂时性死区也就是变量声明到声明完成的区块,这个区块是一个封闭的作用域,直到声明完成。 如果在变量声明之前使用该变量,那么该变量是不可用的,也就被称为暂时性死区。 var 没有暂时性死区,因为var存在变…

Python编程 递归函数

作者简介:一名在校计算机学生、每天分享Python的学习经验、和学习笔记。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.函数执行注意点 二.递归函数 1.递归的介绍 2.例子 前言 本章将会讲解…

新版H5微信网页JS-SDK自定义分享功能实现

1.先用 微信官方文档demo,下载下来去改就行, 概述 | 微信开放文档 2.(后端)填写上认证后的,公众号appid,appsecret。 3.(前端代码) 配置好需要的接口(调试打开debug&a…

自研框架(Webx)整合Zuul网关工作总结

写在前面,最近被分配了一个技术任务,简单描述为自研框架(类比Spring)整合一个微服务网关,并且能用就行。 有人可能会问,想用微服务网关,不是直接引入zuul或者gateway相关的依赖,然后…

【Pandas入门教程】如何合并多个表中的数据

如何合并多个表中的数据 来源:Pandas官网:https://pandas.pydata.org/docs/getting_started/intro_tutorials/index.html 笔记托管:https://gitee.com/DingJiaxiong/machine-learning-study 文章目录如何合并多个表中的数据导包数据准备【1】…

Linux系统基础——文件子系统

title: Linux系统文件子系统 date: 2022-12-18 15:48:24 modify: 2022-12-18 16:48:43 author: wangjianfeng tags: 001-computer-technology, OS, Linux aliases: Linux系统文件子系统 特此说明: 刘超的趣谈linux操作系统是比较重要的参考资料,本文大部分内容和图…

腾讯云轻量应用服务器搭建LAMP 开发环境

LAMP(LinuxApacheMySQLPHP)是目前国际流行的 Web 应用框架,包括了 Linux 操作系统、Apache Web 服务器、MySQL/MariaDB 数据库和 PHP 编程语言环境以及相关组件支持。 说明 LAMP 应用镜像底层基于 CentOS 7.6 64位操作系统。 登录 轻量应用服…

做一个极简 UI 库之代码 lint

eslint, prettier, stylelint 的配置 这三个规则的配置思路:代码美化用 prettier,逻辑代码用 eslint 校验,样式代码用 stylelint 校验。有跟代码美化冲突的以 prettier 为主 为什么要用这么多呢,因为 eslint 不能解析样式代码&a…

数据结构---LRU算法

LRU算法哈希链表自己的JAVA实现LRU全称Least Recently Used,也就是 最近最少使用的意思,是一种内存管理算法,该算法最早应用于Linux操作系统。这个算法基于一种假设:长期不被使用的数据,在未来被用到的几率也不大。因此…

【LeetCode】1754. 构造字典序最大的合并字符串

构造字典序最大的合并字符串 题目描述 给你两个字符串 word1 和 word2 。你需要按下述方式构造一个新字符串 merge :如果 word1 或 word2 非空,选择 下面选项之一 继续操作: 如果 word1 非空,将 word1 中的第一个字符附加到 mer…

node.js+uni计算机毕设项目基于微信小程序校园生活管理LW(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

基于形态学处理的不规则形状图像的几何参数统计,包括输出面积,周长,圆度,矩形度,伸长度

up目录 一、理论基础 二、核心程序 三、测试结果 一、理论基础 形态学是图像处理中应用最为广泛的技术之一,主要用于从图像中提取对表达和描绘区域形状有意义的图像分量,使后续的识别工作能够抓住目标对象最为本质的形状特征,如边界和连通…

C#语言实例源码系列-实现文件分割和合并

专栏分享点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册 👉关于作者 众所周知,人生是一个漫长的流程,不断克服困难,不断反思前进的过程。在这个过程中…