关于 npm 和 webpack ,网上说 "npm是js的包管理工具,webpack是模块打包机,把css、js、less等打包成一个总的js文件供浏览器使用 "
目前个人感觉,npm 用于下载,webpack 用于打包。只要在 npm官网 有的包,就可通过 npm install 包名 下载,在官网不会有重复的包名
npm 与 nodejs 共同发布,所以在 nodejs官网 下载安装了nodejs后就可直接在命令行中使用 npm。通过查看版本检查两者是否安装成功
因为 npm 的更新频率更快,所以可单独更新 npm
或
由于我的nodejs是用的旧版本,所以导致更新 npm 时出错,去官网下载了最新版nodejs后问题解决
安装webpack
webpack要先进行全局安装
到了 webpack4,命令行相关的内容都移到 webpack-cli,所以还需要安装 webpack-cli,否则会出现如下信息
因为 webpack 是全局安装的,所以 webpack-cli 也要全局安装
之后可查看 webpack 版本
小Demo
准备就绪,开始写小案例一个加法计算器,我在F盘新建了个文件夹名为 Demo,进入这个空文件夹shift+右键选择 “在此打开命令行” 或 Powershell 窗口
在当前自己的项目里(这里为 Demo 文件夹)安装局部webpack
之后Demo文件夹会出现node_modules和package-lock.json
然后使用 npm init 命令初始化一个 package.json ,package.json 文件存储着包的信息(包名、版本、项目里所安装的npm包)
运行此命令后,会提示设置相关配置,不想填的话直接回车略过。也可使用 npm init --yes 命令直接快速创建,最后根据需要修改创建好的 package.json 文件即可
之后在Demo下创建两个文件夹( src与dist )和一个空的js文件( webpack.config.js )
src 存放人可以看懂的源代码,具备一定的功能划分如MVC
dist 存放真实上线的代码(减少请求、混淆代码),机器能看懂
webpack.config.js 是webpack工具的配置文件,用来将src下的代码打包生成dist下的代码
接下来要配置 webpack.config.js,好像涉及到nodejs的内容......以后要学习下.....
var path = require(‘path‘); module.exports = { //指定入口文件 entry: { entry: ‘./src/main.js‘ }, //指定出口文件.打包生成build.js,如果没有dist文件夹会自动创建.最好写绝对路径,不然会报下图中的错误Invalid configuration object output: { path: path.join(__dirname,‘dist‘), filename: ‘build.js‘ }, //模块,指定加载器,可配置各种加载器,这样就不担心less等文件的编译问题,这里用不到所以没写 module: {} };
index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <input type="text" id="n1"> + <input type="text" id="n2"> <button id="btn">=</button> <input type="text" id="result"> <script src="../dist/build.js"></script> </body> </html>
main.js
//commonjs方式引入cal对象,由于node的模块作用域,所以必须要导入、引入才能使用这个对象 //var cal = require(‘./cal.js‘); //ES6的模块方式引入 import cal from ‘./cal.js‘; //获取按钮 document.getElementById(‘btn‘).onclick = function(){ var n1 = document.getElementById(‘n1‘).value - 0; var n2 = document.getElementById(‘n2‘).value - 0; var sum = cal.add(n1,n2); document.getElementById(‘result‘).value = sum; };
cal.js
var cal = { add:function(n1,n2){ return n1 + n2; } }; //commonjs导出方式 //module.exports = cal; //ES6导出方式 export default cal;
最后直接在当前目录使用 webpack 命令即可完成打包
浏览器中效果图,点击等号算出结果
npm命令
npm源
由于npm官网是国外的,所以使用 npm install 命令下载时可能会很慢,这时可使用 淘宝的npm镜像 ,相当于将官网的内容复制了一份放在国内。使用方式有三种
? 全局安装淘宝的 cnpm,使用 cnpm 就会通过淘宝的服务器下载。之后,用到 npm 的地方改为 cnpm 即可
? 若不想安装 cnpm 又想使用淘宝的服务器来下载,每次下载时在后面加上--registry=https://registry.npm.taobao.org 即可,如
? 每次手动添加会很麻烦,所以可把这个选项加入配置文件中,之后所有的 npm install 都会默认通过淘宝的服务器下载
查看 npm 配置信息,可使用命令 npm config list
原文地址:https://www.cnblogs.com/Grani/p/9557188.html