2021-12-15 Node、NPM、Babel、Webpack学习

Node.js

运行在服务端的JavaScript 是一个基于Chrome JavaScript 运行时建立的一个平台,底层架构师Javascript 基于谷歌的V8引擎
运行:node hello.js

实现请求响应

在这里插入图片描述

操作mysql数据库

npm install mysql
在这里插入图片描述
在这里插入图片描述

完整的前端项目结构

在这里插入图片描述

Npm

1.npm -init 初始化
npm init -y 初始化并自动配置
2.安装第三方模块
npm install xxxx 或者npm I xxx模块名 @版本号
3.导入模块
const redis = require(“redi”);
4.运行 node xxxx.js 运行过程.js是可以省略的
5.npm模块复用
在项目下 npm install,或者package.json复制到项目目录下,
6.淘宝镜像安装
npm install -g cnpm --registry=hhtps://registry.npm.taobao.org
7.卸载模块
npm uninstall vue jquery

Babel

将Es6的代码转化为Es5的代码
1.安装
npm install -g babel-cli
2.使用
1.创建babel文件夹
2.初始化项目
npm init -y
3.创建文件src/example.js
创建一个.babelrc 定义转码的规则
{
“presets”:[“es2015”],
“plugins”:[]
}
4.安装转码器
npm install --save-dev babel-preset -es2015
5.执行 babel src -d dist

指定输出文件
babel src/example.js --out-file dist1/compiled.js
或者
babel src/example.js -o dist1/compiled.js
整个目录转码
mkdir dist2
babel src --out-dir dist2 或者babel src -d dist2

自定义脚本

改写package.json
执行脚本 npm run 脚本名
在这里插入图片描述

模块化

1.CommonJS规范
每个文件就是一个模块,有自己的作用域,在一个文件里面定义的变量、函数、类都是私有的,对其他文件不可见。
所有文件必须先导出了才能使用
导出
在这里插入图片描述
导入
require
在这里插入图片描述
Es6规范
默认不支持
写法1
导出export
export function getList(){

	}
	导入import
	import {方法名} from '文件位置'

写法2 常用
export default{
方法1(){
},
方法2(){
}
}
import 文件名 from 文件位置
使用 文件名.方法
若不支持 先babel降低版本,转码一下 然后运行

Webpack

前端资源加载/打包工具,它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。
1.安装
npm install -g webpack webpack-cli
安装后查看版本后
webpack -v
webpack合并js
src里存放需要合并的两个js文件并导出
在入口文件main.js导入需要合并的文件
在根目录下定义一个webpack.config.js文件配置打包的规则
执行webpack 查看效果
打包后的文件存放在bundle.js
在这里插入图片描述
webpack-w 监听
使用
在这里插入图片描述

webpack合并css
webpack 本身只能处理JavaScript模块,如果要处理其他类型的文件,即需要使用loader进行转换
Loder可以理解为是模块和资源的转换器
css-loader是将css装载到Javascript style-loader 是让javascript认识css
安装
npm install --save-dev style-loader css-loader
修改webpack.config.js
编译运行
npm run dev

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
code ERESOLVE npm ERR! ERESOLVE could not resolve npm ERR! npm ERR! While resolving: compression-webpack-plugin@3.1.0 npm ERR! Found: webpack@3.12.0 npm ERR! node_modules/webpack npm ERR! peer webpack@"^2.0.0 || ^3.0.0 || ^4.0.0" from @soda/friendly-errors-webpack-plugin@1.7.1 npm ERR! node_modules/@soda/friendly-errors-webpack-plugin npm ERR! @soda/friendly-errors-webpack-plugin@"^1.7.1" from @vue/cli-service@3.12.1 npm ERR! node_modules/@vue/cli-service npm ERR! dev @vue/cli-service@"^3.3.0" from the root project npm ERR! peer webpack@"2 || 3 || 4" from babel-loader@7.1.5 npm ERR! node_modules/babel-loader npm ERR! babel-loader@"^7.1.2" from vue-photo-preview@1.1.3 npm ERR! node_modules/vue-photo-preview npm ERR! vue-photo-preview@"^1.1.3" from the root project npm ERR! 11 more (eslint-loader, extract-text-webpack-plugin, ...) npm ERR! npm ERR! Could not resolve dependency: npm ERR! peer webpack@"^4.3.0 || ^5.0.0" from compression-webpack-plugin@3.1.0 npm ERR! node_modules/compression-webpack-plugin npm ERR! dev compression-webpack-plugin@"^3.1.0" from the root project npm ERR! npm ERR! Conflicting peer dependency: webpack@5.86.0 npm ERR! node_modules/webpack npm ERR! peer webpack@"^4.3.0 || ^5.0.0" from compression-webpack-plugin@3.1.0 npm ERR! node_modules/compression-webpack-plugin npm ERR! dev compression-webpack-plugin@"^3.1.0" from the root project npm ERR! npm ERR! Fix the upstream dependency conflict, or retry npm ERR! this command with --force or --legacy-peer-deps npm ERR! to accept an incorrect (and potentially broken) dependency resolution. npm ERR! npm ERR! npm ERR! For a full report see: npm ERR! C:\Users\zcybi\AppData\Local\npm-cache\_logs\2023-06-08T02_41_32_750Z-eresolve-report.txt
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值