1.关系介绍

1.简单的说 Node.js 就是运行在服务端的 JavaScript。

2.NPM是随同NodeJS一起安装的包管理工具(新版的nodejs已经集成了npm),能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种:

  允许用户从NPM服务器下载别人编写的第三方包到本地使用。

  允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用。

  允许用户将自己编写的包或命令行程序上传到NPM服务器供别人使用。

3.webpack

  webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

4.vue-cli

  是vue脚手架,它是一个专门为单页面应用快速搭建繁杂的脚手架,它可以轻松的创建新的应用程序而且可用于自动生成vue和webpack的项目模板。

===============nodejs==============

2.安装node.js(会将npm也安装成功)

  下载地址:https://nodejs.org/dist/v4.4.3/node-v4.4.3-x64.msi

下载完成安装即可。会自动修改path环境变量,也无需配置。

1.测试下载版本

C:\Users\Administrator>node -v
v4.4.3 C:\Users\Administrator>npm -v
2.15.

2.运行第一个nodejs程序(可以跳过这步)

(1)新建一个JS,命名为server.js。内容如下:

var http = require('http');

http.createServer(function (request, response) {

    // 发送 HTTP 头部
// HTTP 状态值: 200 : OK
// 内容类型: text/plain
response.writeHead(200, {'Content-Type': 'text/plain'}); // 发送响应数据 "Hello World"
response.end('Hello World\n');
}).listen(8888); // 终端打印如下信息
console.log('Server running at http://127.0.0.1:8888/');

第一行请求(require)Node.js 自带的 http 模块,并且把它赋值给 http 变量。

接下来我们调用 http 模块提供的函数: createServer 。这个函数会返回 一个对象,这个对象有一个叫做 listen 的方法,这个方法有一个数值参数, 指定这个 HTTP 服务器监听的端口号。

(2)使用node启动上面服务:

C:\Users\Administrator\Desktop\nodetest> node server.js
Server running at http://127.0.0.1:8888/

(3)访问测试:

补充:此处为nodejs的模块用法

  一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码、JSON 或者编译过的C/C++ 扩展。

比如:

(1)创建模块: hello.js

exports.world = function() {
console.log('hello.js! Hello World');
}

(2)引用模块: main.js

var hello = require('./hello');
hello.world();

  代码 require('./hello') 引入了当前目录下的 hello.js 文件(./ 为当前目录,node.js 默认后缀为 js)。

  Node.js 提供了 exports 和 require 两个对象,其中 exports 是模块公开的接口,require 用于从外部获取一个模块的接口,即所获取模块的 exports 对象。

(3)执行main.js进行测试

E:\HBuilderSpace\vue\node>node ./main.js
hello.js! Hello World

有时候我们只是想把一个对象封装到模块中,格式如下:

module.exports = function() {
// ...
}

(1)hello.js

//hello.js
function Hello() {
var name;
this.setName = function(thyName) {
name = thyName;
};
this.sayHello = function() {
console.log('Hello ' + name);
};
};
module.exports = Hello;

(2)main.js

//main.js
var Hello = require('./hello');
hello = new Hello();
hello.setName('BYVoid');
hello.sayHello();

(3)执行main.js

E:\HBuilderSpace\vue\node>node ./main.js
Hello BYVoid

  模块接口的唯一变化是使用 module.exports = Hello 代替了exports.world = function(){}。 在外部引用该模块时,其接口对象就是要输出的 Hello 对象本身,而不是原先的 exports。

注意:服务端的模块放在哪里?

一开始我们使用http模块语法如下:

var http = require("http");

...

http.createServer(...);

Node.js 中自带了一个叫做 http 的模块,我们在我们的代码中请求它并把返回值赋给一个本地变量。

这把我们的本地变量变成了一个拥有所有 http 模块所提供的公共方法的对象。

Node.js 的 require 方法中的文件查找策略如下:由于 Node.js 中存在 4 类模块(原生模块和3种文件模块),尽管 require 方法极其简单,但是内部的加载却是十分复杂的,其加载优先级也各自不同。

===============npm==============

3.npm使用

npm常用命令如下:

1.安装模块。

  npm 的包安装分为本地安装(local)、全局安装(global)两种

语法:

npm install express          # 本地安装
npm install express -g # 全局安装

本地安装
1. 将安装包放在 ./node_modules 下(运行 npm 命令时所在的目录),如果没有 node_modules 目录,会在当前执行 npm 命令的目录下生成 node_modules 目录。
2. 可以通过 require() 来引入本地安装的包。

全局安装
1. 将安装包放在 /usr/local 下或者你 node 的安装目录。
2. 可以直接在命令行里使用。

例如: 第一行输出了模块的版本号及安装位置。

C:\Users\Administrator>npm install express
express@4.17.1 node_modules\express
├── escape-html@1.0.3
├── content-type@1.0.4
├── array-flatten@1.1.1
├── statuses@1.5.0
├── utils-merge@1.0.1
├── cookie-signature@1.0.6
├── encodeurl@1.0.2
├── methods@1.1.2
├── merge-descriptors@1.0.1
├── content-disposition@0.5.3
├── cookie@0.4.0
├── fresh@0.5.2
├── range-parser@1.2.1
├── parseurl@1.3.3
├── vary@1.1.2
├── serve-static@1.14.1
├── etag@1.8.1
├── path-to-regexp@0.1.7
├── safe-buffer@5.1.2
├── setprototypeof@1.1.1
├── depd@1.1.2
├── qs@6.7.0
├── finalhandler@1.1.2 (unpipe@1.0.0)
├── on-finished@2.3.0 (ee-first@1.1.1)
├── proxy-addr@2.0.5 (forwarded@0.1.2, ipaddr.js@1.9.0)
├── debug@2.6.9 (ms@2.0.0)
├── send@0.17.1 (destroy@1.0.4, ms@2.1.1, mime@1.6.0, http-errors@1.7.3)
├── type-is@1.6.18 (media-typer@0.3.0, mime-types@2.1.25)
├── accepts@1.3.7 (negotiator@0.6.2, mime-types@2.1.25)
└── body-parser@1.19.0 (bytes@3.1.0, raw-body@2.4.0, http-errors@1.7.2, iconv-lite@0.4.24)

我们到  C:\Users\Administrator 目录下可以看到:

补充:npm install 还有两种用法

npm install moduleName # 安装模块到项目目录下

npm install -g moduleName # -g 的意思是将模块安装到全局,具体安装到磁盘哪个位置,要看 npm config prefix 的位置。

npm install -save moduleName # -save 的意思是将模块安装到项目目录下,并在package文件的dependencies节点写入依赖。

npm install -save-dev moduleName # -save-dev 的意思是将模块安装到项目目录下,并在package文件的devDependencies节点写入依赖。

“dependencies”: 这些包都是你的应用程序在生产环境中所需要的。

“devDepedencies”:这些包只是在开发和测试中需要的。

  devDependencies 节点下的模块是我们在开发时需要用的,比如项目中使用的 gulp ,压缩css、js的模块。这些模块在我们的项目部署后是不需要的,所以我们可以使用 -save-dev 的形式安装。-D就是--save-dev 的缩写。

  像 express 这些模块是项目运行必备的,应该安装在 dependencies 节点下,所以我们应该使用 -save 的形式安装。

  正常使用npm install时,会下载dependencies和devDependencies中的模块。

2.查看安装信息

npm list 查看本地模块
npm list -g查看全局模块

例如:

C:\Users\Administrator
└─┬ express@4.17.1
├─┬ accepts@1.3.7
... C:\Users\Administrator\AppData\Roaming\npm
└─┬ cnpm@6.1.0
├── auto-correct@1.0.0

也可以加上模块名称查看版本,例如:

C:\Users\Administrator>npm list express
C:\Users\Administrator
└── express@4.17.1 C:\Users\Administrator>npm list -g cnpm
C:\Users\Administrator\AppData\Roaming\npm
└── cnpm@6.1.0

3.卸载模块

卸载本地模块:

C:\Users\Administrator>npm uninstall express
unbuild express@4.17.1 C:\Users\Administrator>npm ls
C:\Users\Administrator
└── (empty)

  卸载之后对应的目录也会删掉。

卸载全局模块:

C:\Users\Administrator>npm uninstall -g cnpm
unbuild cnpm@6.1.0 C:\Users\Administrator>npm list -g
C:\Users\Administrator\AppData\Roaming\npm
└── (empty)

4.更新模块

npm update express

5.搜索模块

npm search express

6.使用淘宝 NPM 镜像

  国内直接使用 npm 的官方镜像是非常慢的,这里推荐使用淘宝 NPM 镜像。

安装cnpm全局模块:

npm install -g cnpm --registry=https://registry.npm.taobao.org

之后接可以使用 cnpm 命令来安装模块了:

cnpm install [name]

补充:npm查看版本信息

1.查看远程服务器上的版本信息

(1)查看所有版本:

E:\HBuilderSpace\vue-demo>npm view less-loader versions

[
'0.1.0', '0.1.1', '0.1.2', '0.1.3',
'0.2.0', '0.2.1', '0.2.2', '0.5.0',
'0.5.1', '0.6.0', '0.6.1', '0.6.2',
'0.7.0', '0.7.1', '0.7.2', '0.7.3',
'0.7.4', '0.7.5', '0.7.6', '0.7.7',
'0.7.8', '2.0.0', '2.1.0', '2.2.0',
'2.2.1', '2.2.2', '2.2.3', '3.0.0',
'4.0.0', '4.0.1', '4.0.2', '4.0.3',
'4.0.4', '4.0.5', '4.0.6', '4.1.0',
'5.0.0'
]

(2)查看最新版本:

E:\HBuilderSpace\vue-demo>npm view less-loader version
5.0.

(3)查看详细信息:和(1)类似,信息比较全

E:\HBuilderSpace\vue-demo>cnpm info less-loader

less-loader@5.0. | MIT | deps:  | versions:
A Less loader for webpack. Compiles Less to CSS.
https://github.com/webpack-contrib/less-loader dist
.tarball: https://registry.npm.taobao.org/less-loader/download/less-loader-5.0.0
.tgz
.shasum: 498dde3a6c6c4f887458ee9ed3f086a12ad1b466 dependencies:
clone: ^2.1. loader-utils: ^1.1. pify: ^4.0. maintainers:
- bebraw <bebraw@gmail.com>
- d3viant0ne <wiens.joshua@gmail.com>
- ericclemmons <eric@smarterspam.com>
- evilebottnawi <sheo13666q@gmail.com>
- jhnns <mail@johannesewald.de>
- michael-ciniawsky <michael.ciniawsky@gmail.com>
- sokra <tobias.koppers@googlemail.com>
- thelarkinn <sean.larkin@cuw.edu> dist-tags:
latest: 5.0.

2.查看本地模块版本

E:\HBuilderSpace\vue-demo>cnpm list vuex   #查看某个项目的vuex版本,必须在项目下执行
vue-demo@0.1. E:\HBuilderSpace\vue-demo
`-- vuex@3.1. E:\HBuilderSpace\vue-demo>cnpm list express -g  #查看全局express版本
E:\nodejs2
`-- (empty) E:\HBuilderSpace\vue-demo>cnpm ls cnpm -g  #查看全局cnpm版本
E:\nodejs2
`-- (empty)

3.安装指定版本的模块

npm install 模块@版本 

===============webpack==============

4.webpack 的简单使用

  由于我在cnpm安装webpack的时候报错,所以我选择安装最新版本的nde.js。下载地址

  webpack中文文档:https://www.webpackjs.com/concepts/

 

cnpm install webpack -g

在webpack 3中,webpack本身和它的CLI以前都是在同一个包中,但在第4版中,他们已经将两者分开来更好地管理它们。所以我先用cnpm下载好该模块:

cnpm install webpack-cli -g

1.创建1个简单的项目

(1)创建1个目录webpack并进入该目录

(2)用npm进行生成项目信息,并把信息存放到 package.json文件中

E:\HBuilderSpace\vue\webpack>npm init -y
Wrote to E:\HBuilderSpace\vue\webpack\package.json: {
"name": "webpack",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC"
}

(3)安装webpack,由于只在开发环境下会用到,这里用了`--save-dev`标识

cnpm install --save-dev webpack

安装完成文件如下:

E:\HBuilderSpace\vue\webpack>ls
node_modules package.json

node_modules 用来存放我们通过npm命令安装的软件。

package.json 文件记录该项目的元信息,以及一些依赖包信息。

可视化查看结如下;

2.创建页面以及JS文件入口(手动构造webpack目录结构)

1.目录结构如下:

2.dist/index.html内容:

<!-- dist/index.html -->
<!DOCTYPE html>
<html> <head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript" src="bundle.js">
</script>
</head> <body>
</body> </html>

3.src/index.js

// src/index.js
document.write("Hello Webpack!!!");

4.根目录webpack.config.js

// webpack.config.js
const path = require('path'); module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'dist')
}
};

  稍微解释一下。第一行是引入了pat模块,是nodejs的语法。

moudle.exports:

  entry:入口起点(entry point)指示 webpack 应该使用哪个模块,来作为构建其内部依赖图的开始。进入入口起点后,webpack 会找出有哪些模块和库是入口起点(直接和间接)依赖的

  output :告诉 webpack 在哪里输出它所创建的 bundles,以及如何命名这些文件,默认值为 ./dist。基本上,整个应用程序结构,都会被编译到你指定的输出路径的文件夹中。你可以通过在配置中指定一个 output 字段,来配置这些处理过程。

5.根目录下执行webpack命令

E:\HBuilderSpace\vue\webpack>webpack

E:\HBuilderSpace\vue\webpack>"node"  "C:\Users\liqiang\AppData\Roaming\npm\\node_modules\webpack\bin\webpack.js"
Hash: 4d5355ed6a56b418d74b
Version: webpack 4.41.2
Time: 1693ms
Built at: 2019-11-25 22:58:33
Asset Size Chunks Chunk Names
bundle.js 964 bytes 0 [emitted] main
Entrypoint main = bundle.js
[0] ./src/index.js 52 bytes {0} [built]

6.生成的目录结构如下:(会生成bundle.js文件)

7.直接访问index.html即可:

3.loader使用

  Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换。

  所以如果我们需要在应用中添加 css 文件,就需要使用到 css-loader 和 style-loader,他们做两件不同的事情,css-loader 会遍历 CSS 文件,然后找到 url() 表达式然后处理他们,style-loader 会把原来的 CSS 代码插入页面中的一个 style 标签中。

(1)安装loader模块

E:\HBuilderSpace\vue\webpack>cnpm install css-loader style-loader --save-dev

(2)src下新建index.css文件

目录结构:

内容:

body {
color: yellow;
font-size: 40px;
}

(3)修改index.js引入css模块

// src/index.js
require("!style-loader!css-loader!./index.css"); document.write("Hello Webpack!!!");

(4)执行webpack后测试:

上面使用的是内联的loader,import 语句中显式指定 loader,! 将资源中的 loader 分开。

补充:webpack推荐使用的是配置的loader,如下:

(1)修改index.js

// src/index.js
require("./index.css"); document.write("Hello Webpack!!!");

(2)修改webpack.config.js引入css的loader(注意顺序也是先style后css)

// webpack.config.js
const path = require('path'); module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'dist'),
},
module: {
rules: [
{
test: /\.css$/, use: ['style-loader', 'css-loader']
}
]
}
}
;

补充:引入sass

  现代的前端领域,为了方便样式文件的管理与开发,我们一般会在项目引入Sass,或者Less这些技术,然而,浏览器却无法直接解析这类型的样式文件,也就是说如果要用到生产环境中,我们必须把这些资源进行预编译
(1)安装sass-loader
E:\HBuilderSpace\vue\webpack>cnpm install sass-loader --save-dev

(2)src下新建index.scss

body {
color: yellow;
font-size: 40px;
h1 {
background-color: red;
}
}
(3)修改index.js
// src/index.js
require("./index.scss"); document.write("Hello Webpack!!!<br/><h1>标题</h1>");

(4)修改webpack.config.js

// webpack.config.js
const path = require('path'); module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'dist'),
},
module: {
rules: [
{
test: /\.css$/, use: ['style-loader', 'css-loader']
}, {
test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader']
}
]
}
}
;
(5)执行webpack后测试:

4. 插件使用

  插件在 webpack 的配置信息 plugins 选项中指定,用于完成一些 loader 不能完成的工。webpack 自带一些插件,你可以通过 cnpm 安装一些插件。

  由于插件可以携带参数/选项,你必须在 webpack 配置中,向 plugins 属性传入 new 实例。

比如我们可以安装内置的 BannerPlugin 插件,用于在文件头部输出一些注释信息。

修改webpack.config.js

// webpack.config.js
const path = require('path');
const webpack=require('webpack'); module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'dist'),
},
module: {
rules: [
{
test: /\.css$/, use: ['style-loader', 'css-loader']
}, {
test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader']
}
]
},
plugins:[
new webpack.BannerPlugin('头部注释')
]
}
;

重新webpack之后查看bundle.js会加上头部注释:

/*! 头部注释 */!function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=0)}([function(t,e,n){n(1),document.write("Hello Webpack!!!<br/><h1>标题</h1>")},function(t,e,n){var r=n(2);"string"==typeof r&&(r=[[t.i,r,""]]);var o={insert:"head",singleton:!1};n(4)(r,o);r.locals&&(t.exports=r.locals)},function(t,e,n){(t.exports=n(3)(!1)).push([t.i,"body{color:yellow;font-size:40px}body h1{background-color:red}\n",""])},function(t,e,n){"use strict";t.exports=function(t){var e=[];return e.toString=function(){return this.map((function(e){var n=function(t,e){var n=t[1]||"",r=t[3];if(!r)return n;if(e&&"function"==typeof btoa){var o=(a=r,u=btoa(unescape(encodeURIComponent(JSON.stringify(a)))),c="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(u),"/*# ".concat(c," */")),i=r.sources.map((function(t){return"/*# sourceURL=".concat(r.sourceRoot).concat(t," */")}));return[n].concat(i).concat([o]).join("\n")}var a,u,c;return[n].join("\n")}(e,t);return e[2]?"@media ".concat(e[2],"{").concat(n,"}"):n})).join("")},e.i=function(t,n){"string"==typeof t&&(t=[[null,t,""]]);for(var r={},o=0;o<this.length;o++){var i=this[o][0];null!=i&&(r[i]=!0)}for(var a=0;a<t.length;a++){var u=t[a];null!=u[0]&&r[u[0]]||(n&&!u[2]?u[2]=n:n&&(u[2]="(".concat(u[2],") and (").concat(n,")")),e.push(u))}},e}},function(t,e,n){"use strict";var r,o={},i=function(){return void 0===r&&(r=Boolean(window&&document&&document.all&&!window.atob)),r},a=function(){var t={};return function(e){if(void 0===t[e]){var n=document.querySelector(e);if(window.HTMLIFrameElement&&n instanceof window.HTMLIFrameElement)try{n=n.contentDocument.head}catch(t){n=null}t[e]=n}return t[e]}}();function u(t,e){for(var n=[],r={},o=0;o<t.length;o++){var i=t[o],a=e.base?i[0]+e.base:i[0],u={css:i[1],media:i[2],sourceMap:i[3]};r[a]?r[a].parts.push(u):n.push(r[a]={id:a,parts:[u]})}return n}function c(t,e){for(var n=0;n<t.length;n++){var r=t[n],i=o[r.id],a=0;if(i){for(i.refs++;a<i.parts.length;a++)i.parts[a](r.parts[a]);for(;a<r.parts.length;a++)i.parts.push(b(r.parts[a],e))}else{for(var u=[];a<r.parts.length;a++)u.push(b(r.parts[a],e));o[r.id]={id:r.id,refs:1,parts:u}}}}function s(t){var e=document.createElement("style");if(void 0===t.attributes.nonce){var r=n.nc;r&&(t.attributes.nonce=r)}if(Object.keys(t.attributes).forEach((function(n){e.setAttribute(n,t.attributes[n])})),"function"==typeof t.insert)t.insert(e);else{var o=a(t.insert||"head");if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(e)}return e}var l,f=(l=[],function(t,e){return l[t]=e,l.filter(Boolean).join("\n")});function d(t,e,n,r){var o=n?"":r.css;if(t.styleSheet)t.styleSheet.cssText=f(e,o);else{var i=document.createTextNode(o),a=t.childNodes;a[e]&&t.removeChild(a[e]),a.length?t.insertBefore(i,a[e]):t.appendChild(i)}}function p(t,e,n){var r=n.css,o=n.media,i=n.sourceMap;if(o&&t.setAttribute("media",o),i&&btoa&&(r+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(i))))," */")),t.styleSheet)t.styleSheet.cssText=r;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(r))}}var v=null,h=0;function b(t,e){var n,r,o;if(e.singleton){var i=h++;n=v||(v=s(e)),r=d.bind(null,n,i,!1),o=d.bind(null,n,i,!0)}else n=s(e),r=p.bind(null,n,e),o=function(){!function(t){if(null===t.parentNode)return!1;t.parentNode.removeChild(t)}(n)};return r(t),function(e){if(e){if(e.css===t.css&&e.media===t.media&&e.sourceMap===t.sourceMap)return;r(t=e)}else o()}}t.exports=function(t,e){(e=e||{}).attributes="object"==typeof e.attributes?e.attributes:{},e.singleton||"boolean"==typeof e.singleton||(e.singleton=i());var n=u(t,e);return c(n,e),function(t){for(var r=[],i=0;i<n.length;i++){var a=n[i],s=o[a.id];s&&(s.refs--,r.push(s))}t&&c(u(t,e),e);for(var l=0;l<r.length;l++){var f=r[l];if(0===f.refs){for(var d=0;d<f.parts.length;d++)f.parts[d]();delete o[f.id]}}}}}]);

5.模块

对比 Node.js 模块,webpack 模块能够以各种方式表达它们的依赖关系:

(1)ES2015 import 语句

(2)CommonJS require() 语句

(3)AMD define 和 require 语句

(4)css/sass/less 文件中的 @import 语句。

(5)样式(url(...))或 HTML 文件(<img src=...>)中的图片链接(image url)

支持的模块:

  webpack 通过 loader 可以支持各种语言和预处理器编写模块。loader 描述了 webpack 如何处理 非 JavaScript(non-JavaScript) _模块_,并且在 bundle 中引入这些依赖。 webpack 社区已经为各种流行语言和语言处理器构建了 loader,包括:CoffeeScript、TypeScript、ESNext (Babel)、Sass、Less、Stylus

6.监听模式

  如果不想每次修改模块后都重新编译,那么可以启动监听模式。开启监听模式后,没有变化的模块会在编译后缓存到内存中,而不会每次都被重新编译,所以监听模式的整体速度是很快的。

webpack --watch

7.开发环境

  使用 webpack-dev-server 开发服务,这样我们就能通过 localhost:8080 启动一个 express 静态资源 web 服务器,并且会以监听模式自动运行 webpack,在浏览器打开 http://localhost:8080/ 或 http://localhost:8080/webpack-dev-server/ 可以浏览项目中的页面和编译后的资源输出,并且通过一个 socket.io 服务实时监听它们的变化并自动刷新页面。

(1)安装

cnpm install webpack-dev-server -g

(2)webpack.config.js增加如下配置:

    devServer: {
contentBase: './dist'
}

(3)运行启动

E:\HBuilderSpace\vue\webpack>webpack-dev-server

E:\HBuilderSpace\vue\webpack>"node"  "C:\Users\Administrator\AppData\Roaming\npm\\node_modules\webpack-dev-server\bin\webpack-dev-server.js"
i 「wds」: Project is running at http://localhost:8080/
i 「wds」: webpack output is served from /
i 「wds」: Content not from webpack is served from ./dist

(4)修改JS或者CSS会立即更新

(5)去修改没有被入口文件托管的文件,比如index.html文件,就算我们修改html文件的内容,页面也不会自动更新。解决办法,

    devServer: {
contentBase: './dist',
watchContentBase: true
}

  加上watchContentBase属性为true即可。

===============vue-cli==============

5.vue-cli简单使用

  其配置与文档参考:https://cli.vuejs.org/zh/guide/

1.安装vue-cli

cnpm install -g @vue/cli

查看版本:

E:\HBuilderSpace>vue -V

E:\HBuilderSpace>"node"  "C:\Users\Administrator\AppData\Roaming\npm\\node_modules\@vue\cli\bin\vue.js" -V
@vue/cli 4.0.

2.创建vue项目

  两种方式,第一种是命令行创建,第二种是图形化界面创建。

2.1基于命令行创建项目

1.创建项目

E:\HBuilderSpace>vue create vue-demo

E:\HBuilderSpace>"node"  "C:\Users\Administrator\AppData\Roaming\npm\\node_modules\@vue\cli\bin\vue.js" create vue-demo
? Your connection to the default npm registry seems to be slow.
Use https://registry.npm.taobao.org for faster installation? No Vue CLI v4.0.5
? Please pick a preset:
default (babel, eslint)
> Manually select features

按键盘上下键可以选择默认(default)还是手动(Manually),如果选择default,一路回车执行下去就行了。我们选择手动选择,便于选择自己需要的模块:

? Check the features needed for your project:
(*) Babel
( ) TypeScript
( ) Progressive Web App (PWA) Support
(*) Router
(*) Vuex
(*) CSS Pre-processors
>(*) Linter / Formatter
( ) Unit Testing
( ) E2E Testing

选择所需的模块:空格键是选中与取消,A键是全选。我选择了五个模块,回车之后选择自己的配置:

  路由使用history模式;css预处理使用 ass/SCSS (with dart-sass)--node-sass是自动编译实时的,dart-sass需要保存后才会生效;下面的选项用 Airbnb 语法规则; 语法检测选择保存后检查 Lint on save;把babel,postcss,eslint这些配置文件放哪,这里随便选,我选择放在独立文件夹 In dedicated config files

? Use history mode for router? (Requires proper server setup for index fallback in production) Yes
? Pick a CSS pre-processor (PostCSS, Autoprefixer and CSS Modules are supported by default): Sass/SCSS (with dart-sass)
? Pick a linter / formatter config: Airbnb
? Pick additional lint features: (Press <space> to select, <a> to toggle all, <i> to invert selection)Lint on save
? Where do you prefer placing config for Babel, PostCSS, ESLint, etc.? In dedicated config files
? Save this as a preset for future projects? (y/N)

  最后一个是是否要将上面的配置保存为一个默认的配置便于下次使用,如果有需要就输入y然后起个名字就可以了。

  点击回车之后开始下载等待下载依赖模块。下载完成之后会提示如下:

....
found vulnerabilities ⚓ Running completion hooks...

vue-cli安装以及创建一个简单的项目(一)(Node\npm\webpack简单使用)的更多相关文章

  1. Vue Cli安装以及使用

      因为公司项目要用vue框架,所以会用vue-cli来新建项目.用过vue的都知道,要全局安装vue以及脚手架vue-cli,然后执行vue init webpack projectname来新建v ...

  2. Vue技术点整理-Vue CLI安装详解

     一,脚手架安装 Node 版本要求 Vue CLI 需要 Node.js +).你可以使用 nvm 或 nvm-windows 在同一台电脑中管理多个 Node 版本. 1,全局安装Vue CLI ...

  3. 用Vue创建一个新的项目

    vue的安装 Vue.js不支持IE8及以下版本.因为Vue.js使用了ECMAScript5特性,IE8显然不能模拟.Vue.js支持所有兼容ECMAScript5的浏览器. 在用Vue.js构建大 ...

  4. maven 学习---用Eclipse创建一个Maven Web项目

    下面是使用 Eclipse 来创建一个Maven Web项目的说明.这是相当简单的. 现在让我们开始吧! 1: 启动 Eclipse, 点击 File->New->Other 2: 在弹出 ...

  5. 如何用Maven创建一个普通Java项目

    一下内容包括:用Maven创建一个普通Java项目,并把该项目转成IDEA项目,导入到IDEA,最后把这个项目打包成一个jar文件. 有时候运行mvn命令失败,重复运行几次就OK了,无解(可能因为网络 ...

  6. 创建一个 Spring Boot 项目,你会几种方法?

    我最早是 2016 年底开始写 Spring Boot 相关的博客,当时使用的版本还是 1.4.x ,文章发表在 CSDN 上,阅读量最大的一篇有 42W+,如下图: 2017 年由于种种原因,就没有 ...

  7. Java web 开发填坑记 2 -如何正确的创建一个Java Web 项目

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/72566261 本文出自[赵彦军的博客] Java web 开发填坑记 1-如何正确 ...

  8. 创建一个动态Web项目:

    开始你的Eclipse,然后进入“文件”>“新建”>“动态Web项目,然后输入项目名称为HelloWorldStruts2和设置其他的选项,在下面的屏幕: 选择在屏幕上的所有默认选项,最后 ...

  9. IDEA 创建一个普通的java项目

    IntelliJ IDEA 如何创建一个普通的java项目,及创建java文件并运行 首先,确保idea软件正确安装完成,java开发工具包jdk安装完成. IntelliJ IDEA下载地址:htt ...

随机推荐

  1. php捕获Fatal error错误与异常处理

    php中的错误和异常是两个不同的概念. 错误:是因为脚本的问题,比如少写了分号,调用未定义的函数,除0,等一些编译语法错误. 异常:是因为业务逻辑和流程,不符合预期情况,比如验证请求参数,不通过就用 ...

  2. [IDA]系统注释给改掉

    IDA系统自动注释的,如果按 ';',则不会修改成功. 应该按 Shift + ;  这样才可以修改.

  3. C# .NET 使用 NPOI 生成 .xlsx 格式 Excel

    IWorkbook workbook = new XSSFWorkbook(); ISheet sheet = workbook.CreateSheet("-"); IRow ro ...

  4. C# WinForm实现禁止最大化、最小化、双击标题栏、双击图标等操作

    protected override void WndProc(ref Message m) { if (m.Msg==0x112) { switch ((int) m.WParam) { //禁止双 ...

  5. go-gtk环境配置

    go-gtk环境配置(用于go的图形化界面) 弄了一天,终于把这个环境给搭建好了,差不多就是安装msys2->安装gtk的各个版本->安装mingw(我原来装有但不影响,因为重复了,环境变 ...

  6. python基础(24):面向对象三大特性一(继承)

    1. 继承 1.1 什么是继承 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,父类又可称为基类或超类,新建的类称为派生类或子类. python中类的继承分为:单继承和多继 ...

  7. JavaScript几种继承方式

    我们先构建一个Person的构造函数 function Person(name) { this.name=name; } Person.prototype.sayHi=function () { co ...

  8. 2019年上半年收集到的人工智能Python编程干货文章

    2019年上半年收集到的人工智能Python编程干货文章 一文了解Python深拷贝与浅拷贝问题 Python广度优先查找和深度优先查找(内附python教程分享) Python基础之函数2 (参数的 ...

  9. 版本管理·玩转git(分支管理)

    在开发中,遇到这样的情况怎么办? 网站已有支付宝在线支付功能,要添加"微信支付",修改了两个文件,wechat.php.pay.php. 刚做到一半,突然有个紧急bug:支付宝支付 ...

  10. 微服务(入门学习五):identityServer4+ocelot+consul实现简单客户端模式

    简介 主要是采用identity Server4 和ocelot 加上consul 实现简单的客户端模式 开发准备  环境准备 下载并安装Consul具体请参考前几篇的内容 项目介绍 创建ocelot ...