从 0 开始,Vue 的搭建与开发
最近刚好在学习 Vue 开发相关知识,发现这篇文章可以做为基础入门操作手册,标记以作记录。
1 Vue 介绍
Vue.js 是一套构建用户界面的 “渐进式框架”。与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。
如果你之前已经习惯了用 jQuery 操作 DOM,学习 Vue.js 时请先抛开手动操作 DOM 的思维,因为 Vue.js 是数据驱动的,你无需手动操作 DOM。
它通过一些特殊的 HTML 语法,将 DOM 和数据绑定起来。一旦你创建了绑定,DOM 将和数据保持同步,每当变更了数据,DOM 也会相应地更新。
当然,在使用 Vue.js 时,你也可以结合其他库一起使用,比如 jQuery。
1.1 MVVM 模式
MVVM 模式,即 Model-View-ViewModel 模式,其核心是提供对 View 和 ViewModel 的双向数据绑定,这使得 ViewModel 的状态改变可以自动传递给 View。
ViewModel 是 Vue. js 的核心,它是一个 Vue 实例。 Vue 实例是作用于某一个 HTML 元素上的,这个元素可以是 HTML 的 body 元素,也可以是指定了 id 的某个元素。
双向绑定:
-
首先,我们将上图中的
DOM Listeners
和Data Bindings
看作两个工具,它们是实现双向绑定的关键。 -
从 View 侧看,ViewModel 中的
DOM Listeners
工具会帮我们监测页面上 DOM 元素的变化,如果有变化,则更改 Model 中的数据; -
从 Model 侧看,当我们更新 Model 中的数据时,
Data Bindings
工具会帮我们更新页面中的 DOM 元素。
2 Node 环境搭建
Vue 项目通常通过 webpack 工具来构建,而 webpack 命令的执行是依赖 node.js 的环境的,所以首先要安装 node.js。
2.1 Windows 安装 node.js
在进行 Node.js 环境的安装之前,您需要先安装并配置好以下环境:
操作系统:Windows
命令行工具:Node.js 是通过命令行工具进行使用和管理的,因此您需要选择一个适合您的命令行工具。在 Windows 上,您可以选择使用命令提示符(cmd)或 PowerShell。
文本编辑器:Node.js 应用程序通常是使用文本编辑器编写的,因此您需要选择一个适合您的文本编辑器。常用的文本编辑器包括 Visual Studio Code、Sublime Text、Atom 等。
网络连接:在安装 Node.js 和 Node.js 模块时,需要访问网络才能完成下载和安装。因此,您需要确保您的计算机已连接到互联网,并且网络连接稳定。
2.1.1 安装步骤
以下是在 Windows 操作系统上安装 Node.js 的步骤:
-
打开浏览器,并前往 Node.js 官网 Node.js
-
在首页中,您可以看到当前 Node.js 的稳定版本和最新版本。单击 “长期支持版本” 下载,即可下载当前版本的 Node.js 安装程序。
-
下载完成之后,打开下载文件,双击安装包,点击下一步、然后看到更改路径的地方。
-
点击 change 按钮,更换到自己的指定安装位置(我装在了 D 盘),点击下一步,最后安装成功即可。
2.1.2 验证安装
为了验证 Node.js 是否已成功安装,您可以在 CMD 命令行工具中输入以下命令:
node -v
此命令将输出 Node.js 的版本号,如果输出的版本号与您下载的版本号相同,则说明 Node.js 已成功安装。
2.1.3 修改全局安装路径、缓存路径,环境变量配置
node_global
目录存储全局安装的 Node.js 模块,而 node_cache
目录存储 Node.js 模块的缓存文件。
在 node_global
目录中,您可以找到全局安装的 Node.js 模块的文件和元数据,例如包的源代码、可执行文件、依赖项和描述文件等。这些模块通常是在系统中的任何位置都可以访问的,因为它们已经被全局安装了。
与此相反,node_cache
目录包含已经下载过的 Node.js 模块的缓存文件。每当您使用 npm install
命令安装 Node.js 模块时,npm 都会尝试从 node_cache
目录中查找相同模块的缓存文件。
如果找到了缓存文件,npm 将使用它们来加快安装过程,而不必再次下载相同的文件。这样可以节省时间和带宽,并减少网络流量。
请注意,node_global
目录和 node_cache
目录是不同的目录,如果您更改了其中任何一个目录的位置,那么全局安装的 Node.js 模块和缓存文件将被保存到新的路径中。
如果没有设置全局目录 node_global,那么全局安装的文件将会保存到 C:\用户\user\AppData\Roaming\npm
(user 是自己设置的计算机名字)
所以,安装好 nodejs 后,要设置一下 node_global 和 node_cache(node 缓存文件夹)
2.1.3.1 在 Nodejs 安装目录创建 node_global 和 node_cache 文件夹
2.1.3.2 打开 Cmd 命令,依次输入:
npm config set prefix "D:\Nodejs\node_global"
npm config set cache "D:\Nodejs\node_cache"
npm config set prefix "D:\Nodejs\node_global"
:将 Node.js 全局安装包的安装路径设置为 “D:\Nodejs\node_global”。
这意味着在使用 npm install -g 命令全局安装 Node.js 模块时,将会将模块安装到指定的目录中。
npm config set cache “D:\Nodejs\node_cache”
:将 Node.js 模块缓存路径设置为 “D:\Nodejs\node_cache”。这意味着在使用 npm install 命令安装 Node.js 模块时,将会将模块缓存到指定的目录中。
2.1.3.3 修改系统环境变量
在 Windows 操作系统上,可以通过以下步骤打开环境变量编辑器:
- 打开 “开始” 菜单,搜索并选择 “控制面板” 选项。
- 在控制面板中,选择 “系统和安全” 选项。
- 选择 “系统” 选项,然后在菜单中选择 “高级系统设置” 选项。
- 在弹出窗口中,选择 “环境变量” 按钮,这将打开环境变量编辑器。
或者,您也可以通过以下步骤在命令提示符(cmd)中打开环境变量编辑器:
- 打开命令提示符(cmd)窗口,输入以下命令并按下回车键
rundll32.exe sysdm.cpl,EditEnvironmentVariables
这将打开环境变量编辑器。如图所示:
将用户变量下的 Path 路径中编辑追加一行 D:\Nodejs\node_global
,在系统变量下新建变量名为:NODE_PATH 变量值为:D:\Nodejs\node_global\node_modules
修改完之后,在系统变量中,点击 Path, 在最后一行加入:
%NODE_PATH%
确定保存。
2.1.4 更改淘宝镜像
npm 初始源是指 npm 包管理器在安装和发布 Node.js 模块时默认使用的官方源。由于 npm 官方源在全球范围内都很受欢迎,因此在某些地区可能会出现访问速度较慢或连接不稳定的问题。为了解决这些问题,许多 Node.js 开发者选择使用淘宝源来代替 npm 官方源。
淘宝源是由淘宝团队在国内搭建的一个 npm 镜像源,目的是为了提高国内 Node.js 开发者使用 npm 时的访问速度和稳定性。与 npm 官方源相比,淘宝源的下载速度更快,而且在国内访问更加稳定。
- 要更改 npm 的默认源为淘宝源,您可以使用以下命令:
npm config set registry https://registry.npm.taobao.org
这将会将 npm 的默认源更改为淘宝源。
如果您想要恢复默认的 npm 官方源,可以使用以下命令:
npm config set registry https://registry.npmjs.org
请注意,更改 npm 源可能会对您的系统产生不可预知的影响,因此在更改源之前,请确保仔细阅读相关文档并了解可能的后果。
- 运行 npm config get registry 命令将返回当前 npm 源的 URL:
npm config get registry
- 使用淘宝源全局安装 cnpm。
cnpm 是一个基于 npm 的淘宝定制版,可以在国内更快地安装 Node.js 包,您可以使用以下命令:
npm install -g cnpm --registry=https://registry.npm.taobao.org
使用这两个命令的目的是为了在国内使用 npm 更快地安装 Node.js 包。首先,将 npm 源设置为淘宝源,以便在使用 npm 安装包时自动使用淘宝源。然后,使用淘宝源全局安装 cnpm,以便在命令行中使用 cnpm 命令来代替 npm 命令,从而更快地安装 Node.js 包。需要注意的是,使用 cnpm 替代 npm 时,一些 npm 命令可能会有所不同或不支持。
此外,使用 cnpm 时也可能会遇到包依赖问题,因为 cnpm 可能会与某些 npm 依赖包不兼容。因此,在使用 cnpm 时,请确保您已经了解其特性和限制,并根据需求进行选择。
如下图:安装成功
以上就配置成功了,如果有出错的,可以再检查下,注意环境变量不要错了。
2.2 NPM 使用介绍
NPM 是随同 NodeJS 一起安装的包管理工具,能解决 NodeJS 代码部署上的很多问题,常见的使用场景有以下几种:
-
允许用户从 NPM 服务器下载别人编写的第三方包到本地使用。
-
允许用户从 NPM 服务器下载并安装别人编写的命令行程序到本地使用。
-
允许用户将自己编写的包或命令行程序上传到 NPM 服务器供别人使用。
由于新版的 nodejs 已经集成了 npm,所以之前 npm 也一并安装好了。同样可以通过输入 npm -v
来测试是否成功安装。命令如下,出现版本提示表示安装成功:
npm -v
如果你安装的是旧版本的 npm,可以很容易得通过 npm 命令来升级,命令如下:
npm install npm -g
如果是 Window 系统使用以下命令即可:
npm install npm -g
2.2.1 使用 Npm 命令安装模块
npm 安装 Node.js 模块语法格式如下:
npm install <Module Name>
以下实例,我们使用 npm 命令安装常用的 Node.js web 框架模块 express:
npm install express
安装好之后,express 包就放在了工程目录下的 node_modules 目录中,因此在代码中只需要通过 require('express')
的方式就好,无需指定第三方包路径。
var express = require('express');
2.2.2 全局安装与本地安装
npm 的包安装分为本地安装(local)、全局安装(global)两种,从敲的命令行来看,差别只是有没有 -g
而已,比如
npm install express # 本地安装
npm install express -g # 全局安装
如果出现以下错误:
npm err! Error: connect ECONNREFUSED 127.0.0.1:8087
解决办法为:
npm config set proxy null
2.2.2.1 本地安装
-
- 将安装包放在
./node_modules
下(运行 npm 命令时所在的目录),如果没有 node_modules 目录,会在当前执行 npm 命令的目录下生成 node_modules 目录。
- 将安装包放在
-
- 可以通过 require() 来引入本地安装的包。
2.2.2.2 全局安装
-
1. 将安装包放在
/usr/local
下或者你 node 的安装目录。 -
- 可以直接在命令行里使用。
如果你希望具备两者功能,则需要在两个地方安装它或使用 npm link。接下来我们使用全局方式安装 express
npm install express -g
安装过程输出如下内容,第一行输出了模块的版本号及安装位置。
express@4.13.3 node_modules/express
├── escape-html@1.0.2
├── range-parser@1.0.2
├── merge-descriptors@1.0.0
├── array-flatten@1.1.1
├── cookie@0.1.3
├── utils-merge@1.0.0
├── parseurl@1.3.0
├── cookie-signature@1.0.6
├── methods@1.1.1
├── fresh@0.3.0
├── vary@1.0.1
├── path-to-regexp@0.1.7
├── content-type@1.0.1
├── etag@1.7.0
├── serve-static@1.10.0
├── content-disposition@0.5.0
├── depd@1.0.1
├── qs@4.0.0
├── finalhandler@0.4.0 (unpipe@1.0.0)
├── on-finished@2.3.0 (ee-first@1.1.1)
├── proxy-addr@1.0.8 (forwarded@0.1.0, ipaddr.js@1.0.1)
├── debug@2.2.0 (ms@0.7.1)
├── type-is@1.6.8 (media-typer@0.3.0, mime-types@2.1.6)
├── accepts@1.2.12 (negotiator@0.5.3, mime-types@2.1.6)
└── send@0.13.0 (destroy@1.0.3, statuses@1.2.1, ms@0.7.1, mime@1.3.4, http-errors@1.3.1)
2.2.2.3 查看安装信息
你可以使用以下命令来查看所有全局安装的模块:
npm list -g
如果要查看某个模块的版本号,可以使用命令如下:
npm list grunt
2.2.3 使用 package.json
package.json 位于模块的目录下,用于定义包的属性。
接下来让我们来看下 express 包的 package.json 文件,位于 node_modules/express/package.json
内容:
{
"name": "express",
"description": "Fast, unopinionated, minimalist web framework",
"version": "4.13.3",
"author": {
"name": "TJ Holowaychuk",
"email": "tj@vision-media.ca"
},
"contributors": [
{
"name": "Aaron Heckmann",
"email": "aaron.heckmann+github@gmail.com"
},
{
"name": "Ciaran Jessup",
"email": "ciaranj@gmail.com"
},
{
"name": "Douglas Christopher Wilson",
"email": "doug@somethingdoug.com"
},
{
"name": "Guillermo Rauch",
"email": "rauchg@gmail.com"
},
{
"name": "Jonathan Ong",
"email": "me@jongleberry.com"
},
{
"name": "Roman Shtylman",
"email": "shtylman+expressjs@gmail.com"
},
{
"name": "Young Jae Sim",
"email": "hanul@hanul.me"
}
],
"license": "MIT",
"repository": {
"type": "git",
"url": "git+https://github.com/strongloop/express.git"
},
"homepage": "http://expressjs.com/",
"keywords": [
"express",
"framework",
"sinatra",
"web",
"rest",
"restful",
"router",
"app",
"api"
],
"dependencies": {
"accepts": "~1.2.12",
"array-flatten": "1.1.1",
"content-disposition": "0.5.0",
"content-type": "~1.0.1",
"cookie": "0.1.3",
"cookie-signature": "1.0.6",
"debug": "~2.2.0",
"depd": "~1.0.1",
"escape-html": "1.0.2",
"etag": "~1.7.0",
"finalhandler": "0.4.0",
"fresh": "0.3.0",
"merge-descriptors": "1.0.0",
"methods": "~1.1.1",
"on-finished": "~2.3.0",
"parseurl": "~1.3.0",
"path-to-regexp": "0.1.7",
"proxy-addr": "~1.0.8",
"qs": "4.0.0",
"range-parser": "~1.0.2",
"send": "0.13.0",
"serve-static": "~1.10.0",
"type-is": "~1.6.6",
"utils-merge": "1.0.0",
"vary": "~1.0.1"
},
"devDependencies": {
"after": "0.8.1",
"ejs": "2.3.3",
"istanbul": "0.3.17",
"marked": "0.3.5",
"mocha": "2.2.5",
"should": "7.0.2",
"supertest": "1.0.1",
"body-parser": "~1.13.3",
"connect-redis": "~2.4.1",
"cookie-parser": "~1.3.5",
"cookie-session": "~1.2.0",
"express-session": "~1.11.3",
"jade": "~1.11.0",
"method-override": "~2.3.5",
"morgan": "~1.6.1",
"multiparty": "~4.1.2",
"vhost": "~3.0.1"
},
"engines": {
"node": ">= 0.10.0"
},
"files": [
"LICENSE",
"History.md",
"Readme.md",
"index.js",
"lib/"
],
"scripts": {
"test": "mocha --require test/support/env --reporter spec --bail --check-leaks test/ test/acceptance/",
"test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --require test/support/env --reporter spec --check-leaks test/ test/acceptance/",
"test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --require test/support/env --reporter dot --check-leaks test/ test/acceptance/",
"test-tap": "mocha --require test/support/env --reporter tap --check-leaks test/ test/acceptance/"
},
"gitHead": "ef7ad681b245fba023843ce94f6bcb8e275bbb8e",
"bugs": {
"url": "https://github.com/strongloop/express/issues"
},
"_id": "express@4.13.3",
"_shasum": "ddb2f1fb4502bf33598d2b032b037960ca6c80a3",
"_from": "express@*",
"_npmVersion": "1.4.28",
"_npmUser": {
"name": "dougwilson",
"email": "doug@somethingdoug.com"
},
"maintainers": [
{
"name": "tjholowaychuk",
"email": "tj@vision-media.ca"
},
{
"name": "jongleberry",
"email": "jonathanrichardong@gmail.com"
},
{
"name": "dougwilson",
"email": "doug@somethingdoug.com"
},
{
"name": "rfeng",
"email": "enjoyjava@gmail.com"
},
{
"name": "aredridel",
"email": "aredridel@dinhe.net"
},
{
"name": "strongloop",
"email": "callback@strongloop.com"
},
{
"name": "defunctzombie",
"email": "shtylman@gmail.com"
}
],
"dist": {
"shasum": "ddb2f1fb4502bf33598d2b032b037960ca6c80a3",
"tarball": "http://registry.npmjs.org/express/-/express-4.13.3.tgz"
},
"directories": {},
"_resolved": "https://registry.npmjs.org/express/-/express-4.13.3.tgz",
"readme": "ERROR: No README data found!"
}
2.2.3.1 Package.json 属性说明
-
name - 包名。
-
version - 包的版本号。
-
description - 包的描述。
-
homepage - 包的官网 url 。
-
author - 包的作者姓名。
-
contributors - 包的其他贡献者姓名。
-
dependencies - 依赖包列表。如果依赖包没有安装,npm 会自动将依赖包安装在 node_module 目录下。
-
repository - 包代码存放的地方的类型,可以是 git 或 svn,git 可在 Github 上。
-
main - main 字段指定了程序的主入口文件,require('moduleName') 就会加载这个文件。这个字段的默认值是模块根目录下面的 index.js。
-
keywords - 关键字
2.2.4 卸载模块
我们可以使用以下命令来卸载 Node.js 模块。
npm uninstall express
卸载后,你可以到 /node_modules/ 目录下查看包是否还存在,或者使用以下命令查看:
npm ls
2.2.5 更新模块
我们可以使用以下命令更新模块:
npm update express
2.2.6 搜索模块
使用以下来搜索模块:
npm search express
2.2.7 创建模块
创建模块,package.json
文件是必不可少的。
我们可以使用 NPM 生成 package.json
文件,生成的文件包含了基本的结果。
npm init
This utility will walk you through creating a package.json file.
It only covers the most common items, and tries to guess sensible defaults.
See `npm help json` for definitive documentation on these fields
and exactly what they do.
Use `npm install <pkg> --save` afterwards to install a package and
save it as a dependency in the package.json file.
Press ^C at any time to quit.
name: (node_modules) runoob # 模块名
version: (1.0.0)
description: Node.js 测试模块(www.runoob.com) # 描述
entry point: (index.js)
test command: make test
git repository: https://github.com/runoob/runoob.git # Github 地址
keywords:
author:
license: (ISC)
About to write to ……/node_modules/package.json: # 生成地址
{
"name": "runoob",
"version": "1.0.0",
"description": "Node.js 测试模块(www.runoob.com)",
……
}
Is this ok? (yes) yes
以上的信息,你需要根据你自己的情况输入。在最后输入 "yes" 后会生成 package.json 文件。接下来我们可以使用以下命令在 npm 资源库中注册用户(使用邮箱注册):
npm adduser
Username: mcmohd
Password:
Email: (this IS public) mcmohd@gmail.com
接下来我们就用以下命令来发布模块:
npm publish
如果你以上的步骤都操作正确,你就可以跟其他模块一样使用 npm 来安装。
2.2.7.1 版本号
使用 NPM 下载和发布代码时都会接触到版本号。NPM 使用语义版本号来管理代码,这里简单介绍一下。
语义版本号分为 X.Y.Z 三位,分别代表主版本号、次版本号和补丁版本号。当代码变更时,版本号按以下原则更新。
-
如果只是修复 bug,需要更新 Z 位。
-
如果是新增了功能,但是向下兼容,需要更新 Y 位。
-
如果有大变动,向下不兼容,需要更新 X 位。
版本号有了这个保证后,在申明第三方包依赖时,除了可依赖于一个固定版本号外,还可依赖于某个范围的版本号。例如 "argv": "0.0.x" 表示依赖于 0.0.x 系列的最新版 argv。
NPM 支持的所有版本号范围指定方式可以查看【官方文档】npm。
2.2.8 NPM 常用命令
除了本章介绍的部分外,NPM 还提供了很多功能,package. json 里也有很多其它有用的字段。除了可以在 doc - npm 查看官方文档外,这里再介绍一些 NPM 常用命令。
NPM 提供了很多命令,例如 install 和 publish,使用 npm help 可查看所有命令。
-
NPM 提供了很多命令,例如
install
和publish
,使用npm help
可查看所有命令。 -
使用
npm help <command>
可查看某条命令的详细帮助,例如npm help install
。 -
在
package.json
所在目录下使用npm install . -g
可先在本地安装当前命令行程序,可用于发布前的本地测试。 -
使用
npm update <package>
可以把当前目录下node_modules
子目录里边的对应模块更新至最新版本。 -
使用
npm update <package> -g
可以把全局安装的对应命令行程序更新至最新版。 -
使用
npm cache clear
可以清空 NPM 本地缓存,用于对付使用相同版本号发布新版本代码的人。 -
使用
npm unpublish <package>@<version>
可以撤销发布自己发布过的某个版本代码。
删除以前安装 node_modules,如果你遇到了使用 npm 安装 node_modules 总是提示报错:报错: npm resource busy or locked….. 。可以先删除以前安装的 node_modules :
npm cache clean
npm install
2.3 Linux 安装 node.js
node.js 的官方地址为:Node.js — Download Node.js®
wget https://nodejs.org/dist/v16.13.2/node-v16.13.2-linux-x64.tar.xz
tar -xf node-v16.13.2-linux-x64.tar.xz -C /opt
ls /opt/node-v16.13.2-linux-x64/bin # 可以看到node npm等
# 添加环境变量
# 在 /etc/profile尾部添加以下两行
export NODE_HOME=/opt/node-v16.13.2-linux-x64/bin
export PATH=$NODE_HOME:$PATH
# 刷新环境变量使其生效
source /etc/profile
# 查看是否安装配置成功
npm -v # 8.1.2
node -v # v16.13.2
配置国内 npm 镜像,安装成功后,后续用到 npm
的地方使用 cnpm
可以加速下载依赖等
# 为了提高我们的效率,可以使用淘宝的镜像:http://npm.taobao.org/
npm install -g cnpm –registry=https://registry.npm.taobao.org
# 测试是否安装成功
cnpm -v
3 Vue 环境搭建
3.1 安装
3.1.1 安装 Webpack
Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。
webpack 是打包代码时依赖的核心内容,而 webpack-cli 是一个用来在命令行中运行 webpack 的工具。这里先安装 webpack,输入以下命令进行安装。
npm install webpack -g
npm install --global webpack-cli
从图中我们可以看出,Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。
由于 npm 安装速度慢,本教程使用了淘宝的镜像及其命令 cnpm。使用 cnpm 安装 webpack:cnpm install webpack -g
。webpack 是打包代码时依赖的核心内容,而 webpack-cli 是一个用来在命令行中运行 webpack 的工具。
npm install --global webpack-cli
3.1.2 安装 Vue 相关文件
之后再输入以下命令进行安装 vue 相关文件。
cnpm install vue -g //安装vue.js
cnpm install vue-router -g //安装vue-router
cnpm install vue-cli -g //安装vue脚手架
cnpm install vue -g // 安装 vue.js
npm install vue-router -g // 安装 vue-router
cnpm install vue-cli -g // 安装 vue 脚手架
安装完后的 node_global 文件夹。
输入 vue -V
查看 vue 安装版本,如果成功显示版本号说明安装 vue 成功。
3.1.3 新建并启动 Vue3 项目
新建 vue3 文件夹,输入以下命令。
d: //最好不要在C盘创建vue项目
mkdir -p vue-app/vue3
cd vue-app/vue3
vue create vue3-demo // vue3-demo 项目名
前面 cnpm install vue-cli -g // 安装 vue 脚手架
, 只能新建 vue 2 的项目。执行 vue create vue3-demo
的时候,会提示要卸载老的 vue-cli , 执行 npm install @vue/cli
安装新的 vue-cli
npm install @vue/cli
执行 npm install @vue/cli 后显示的界面。
接着输入以下命令进行创建 vue3 项目。
vue3 create 项目名
vue create vue3-demo // vue3-demo 项目名
默认选择第一个 Vue 3 创建,然后直接回车。
这里创建需要等待几分钟,等到出现以下界面,说明已经创建成功。
输入以下命令。
d:
cd vue-app/vue3/vue3-demo
npm run serve
开始 building 构建
开始启动
启动成功
复制路径到浏览器进行运行。
vue3 项目的运行停止,ctrl+c,然后选择 Y 就可进行停止退出。
3.2 VS Code 安装、配置、使用(windows10 64)
3.2.1 VS Code 下载和安装
下载地址 Download Visual Studio Code - Mac, Linux, Windows
傻瓜安装,这个就不用赘述了。
3.2.2 配置插件(必须联网)
总结了几个常用的、必备的、满足需求并安装最少插件的插件。
No1: Vetur
vue 代码自动格式化插件,统一代码格式。
No2: JavaScript (ES6) code snippets
包含 ES6 语法中的 JavaScript 代码段(支持 JavaScript 和 TypeScript),方便编写 JS 代码。
No3: Bracket Pair Colorizer
带颜色的括号,方便查看代码层次结构,强烈推荐。
No4: Sass/Less/Stylus/Pug/Jade/Typescript/Javascript Compile Hero Pro
能识别出代码的关键词并进行关键词美化,支持 Sass、Less、Stylus、Pug、Jade、Typescript、Javascript…
No5: Path Intellisense
自动补全路径,自动完成文件名的代码补全,处理文件路径的时候可以自动填写。
No6: npm Intellisense
在导入语句中自动完成 npm 模块的 Visual Studio 代码插件。
No7: open in browser
运行 HTML 文件,在 HTML 文件中右键 “在浏览器打开 “就可以运行 HTML 文件。
No8: Chinese (Simplified) Language Pack for Visual Studio Code
vscode 上的简体中文语言包,汉化 vscode 的插件,如果是刚用 vscode 不久的话建议安上这款插件。
4 Npm Install 安装机制及实现原理
4.1 Npm 安装机制
4.2 Npm 实现原理
(npm install 命令发起后,根据工程定义决定是否执行 preinstall,install、postinstall 是 npm install 命令必然会执行的阶段)
确定需要哪些依赖模块若 npm install 后面没有添加指定下载内容,则先从工程的 package.json 的 dependencies 和 devDependencies 属性中读取首层依赖模块的信息; 若指定了下载内容,则指定首层依赖为该内容.
工程本身是整颗依赖树的根节点,每个首层依赖模块都是根节点下面的一棵子树,npm 会开启多进程从每个首层依赖模块中逐步寻找更深层次的节点。
如何获取依赖模块:
获取模块信息 (version:包唯一的版本号; resolved:安装源; integrity:表明包完整性的 hash 值(验证包是否已失效);dev:如果为 true,则此依赖关系仅是顶级模块的开发依赖关系或者是一个的传递依赖关系; requires:依赖包所需要的所有依赖项,对应依赖包 package.json 里 dependencies 中的依赖项 dependencies:依赖包 node_modules 中依赖的包,与顶层的 dependencies 一样的结构)
在下载一个模块之前,首先要确定版本 若非指定下载模块,package.json 中往往是 semantic version 。此时如果版本描述文件(npm-shrinkwrap.json 或 package-lock.json)中有该模块信息直接拿即可,如果没有则从仓库获取;若指定下载模块,指定版本号,则根据用户指定的版本号从仓库获取;若指定下载模块,未指定版本号,则从仓库获取最新版本
获取模块实体上一步会获取到模块的压缩包地址(resolved 字段),npm 会用此地址检查本地缓存,缓存中有就直接拿,如果没有则从仓库中下载。
查找该模块依赖根据 requires 字段查找该模块需要的依赖,如果有依赖则回到第一步,如果没有则停止。
模块扁平化上一步获取到的是一颗完整的依赖树,其中可能包含大量重复模块。比如 A 模块依赖于 lodash,B 模块同样依赖于 lodash。在 npm3 以前会严格按照依赖树的结构进行安装,因此会造成模块冗余。
从 npm3 开始默认加入了一个 dedupe 的过程。它会遍历所有节点,逐个将模块放在根节点下面,也就是 node-modules 的第一层。当发现有重复模块时,则将其丢弃。比如 node-modules 下已经有了一个 lodash@1.0.0,此时又发现某模块下有一个 loader@1.0.0,则直接将其从依赖树中丢弃。
这里需要对重复模块进行一个定义, 它指的是模块名相同的 semver 兼职,每一个 semver 都对应一段版本的允许范围,如果两个模块的版本允许范围存在交集,那么就可以得到兼容一个版本,而不必要版本号完全一致,这可以使更多冗余模块在 dedupe 过程中被去掉。
安装模块这一步将会更新工程中的 node_modules, 并按照 preinstall、install、postinstall 的顺序执行模块中的生命周期函数。npm 安装依赖时,会下载到缓存当中,然后解压到项目的 node_modules 中。
再次安装依赖的时候,会根据 package-lock.json 中存储的 integrity、version、name 信息生成一个唯一的 key,然后拿着 key 去目录中查找对应的缓存记录,如果有缓存资源,就会找到 tar 包的 hash 值,根据 hash 再去找缓存的 tar 包,并把对应的二进制文件解压到相应的项目 node_modules 下面,省去了网络下载资源的开销
执行工程自身生命周期当前 npm 工程如果定义了钩子此时会按照 preinstall、install、postinstall 的顺序被执行。最终生成或更新版本描述文件,npm install 过程完成。
原文转载:微信公众平台