基本使用
初始化项目
创建文件
安装jQuery
index.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>隔行变色</title> <script src="./index.js"></script> </head> <body> <ul> <li>这是第 1 个li</li> <li>这是第 2 个li</li> <li>这是第 3 个li</li> <li>这是第 4 个li</li> <li>这是第 5 个li</li> <li>这是第 6 个li</li> <li>这是第 7 个li</li> <li>这是第 8 个li</li> <li>这是第 9 个li</li> </ul>
</body> </html>
|
index.js
1 2 3 4 5 6 7
| import $ from 'jquery'
$(function(){ $("li:odd").css("background-color","red") $("li:even").css("background-color","pink") })
|
运行index.html,就会报错,这时需要安装webpack
安装webpack
⛔ 安装webpack遇到的版本问题
要安装最新版本或特定版本,请运行以下命令之一:
1 2 3
| npm install --save-dev webpack npm install --save-dev webpack@<version>
|
如果你使用 webpack 4+ 版本,你还需要安装 CLI。
1
| npm install --save-dev webpack-cli
|
创建webpack的配置文件webpack.config.js
1 2 3 4 5 6 7 8 9
|
modle.exports={
// 代表webpack的运行的模式, // 可选的值有两个 development 和 production mode : "development" }
|
修改package.json
1 2 3 4
| "scripts":{ "dev":"webpack" }
|
运行
修改index.html的引入js路径
1 2
| scr="./index.js" 改成 src="./dist/main.js"
|
entry和output
1 2 3 4 5 6 7 8 9 10 11 12
| const path = require("path") module.exports = { entry:path.join(__dirname,"./src/index1.js"), output:{ path:path.join(__dirname,"./dist2"), filename:"bundle.js" } }
|
修改代码实时生效插件
1
| npm install webpack-dev-server --save-dev
|
修改package.json
1 2 3
| "scripts": { "dev": "webpack serve" }
|
1
| npm i --save-dev html-webpack-plugin
|
修改webpack.config.json
1 2 3 4 5 6 7 8 9 10 11 12 13
| const htmlplugin = require("html-webpack-plugin")
plugin = new htmlplugin({ template:"./src/index.html", filename:"./index.html" })
module.exports = { mode:"development", plugins:[plugin] }
|
配置devServer
1 2 3 4 5 6 7 8 9 10
| module.exports = { mode:"development", plugins:[plugin], devServer:{ open:true, port:10086 } }
|
loader
webpack默认只处理js格式的文件,比如要处理CSS,需要安装
1 2
| npm install --save-dev css-loader npm install --save-dev style-loader
|
在src下新建css文件夹,在css文件夹下新建一个index.css
在index.js导入css文件
1 2
| import "./css/index.css"
|
配置webpack.config.js
1 2 3 4 5 6 7 8 9 10 11 12 13
| module.exports = { mode:"development", module:{ rules:[ { test:/\.css$/,use:["style-loader","css-loader"] } ] } }
|
less-loader
在上面的css文件夹下,创建个index.less文件
1 2 3 4 5 6 7 8 9 10
| html,body,ul{ padding: 0; margin: 0; li{ line-height: 30px; padding-left: 20px; font-size: 12px; } }
|
1 2
| npm install less -D npm install less less-loader --save-dev
|
配置webpack.config.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| module.exports = { mode:"development", module:{ // 所有第三方文件模块的匹配规则 rules:[ // 文件后缀的匹配规则 // 处理css {test:/\.css$/,use:["style-loader","css-loader"]}, {test: /\.less$/, use: ["style-loader", "css-loader", "less-loader",], }, ] } }
|
图片loader
没学
babel-loader
没学
build
打包优化
自动清理dist目录下的旧文件
1
| npm install --save-dev clean-webpack-plugin
|
1 2 3 4 5 6 7 8
| const { CleanWebpackPlugin } = require('clean-webpack-plugin');
module.exports = { plugins:[plugin,new CleanWebpackPlugin()], output:{ path:path.join(__dirname,"./dist") } }
|
Source Map
一个信息文件,存储这位置信息,存储压缩混淆后的代码,所对应的转换钱的位置
1 2 3 4 5 6
| module.exports = { mode:"development", devtool:"eval-source-map" }
|
@
的原理
标识src源代码目录,从外往里找, 就可以不用使用../
从里往外找
告诉webpack,@的目录
1 2 3 4 5 6 7
| module.exports = { resolve:{ alias:{ "@":path.join(__dirname,"./src/") } } }
|
Eslint
1 2 3 4 5 6 7 8 9 10
| { "semi": true, "singleQuote": false, "trailingComma": "none" }
|
在Vue项目的根目录中创建vue.config.js文件
1 2 3 4 5 6 7 8 9 10
| # 在脚手架生成的代码添加 module.exports = defineConfig({ # 要添加的代码 lintOnSave:false })
# 或者 module.exports = { lintOnSave:false }
|
入门应用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| var http = require('http');
http.createServer(function (request, response) { response.writeHead(200, {'Content-Type': 'text/plain'});
response.end('Hello World\n'); }).listen(8888);
console.log('Server running at http://127.0.0.1:8888/');
node server.js
|
Npm升级
Node.js
mac安装
npm更换版本
node.js更换版本
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| # node更换 sudo npm install n -g
# 安装指定版本号的nodejs,记得使用sudo sudo n 14.16.0
# 切换nodejs版本号 n # 输入n之后,打印的数据 ο node/14.16.0
------------------------------------------ # 使用nvm更换版本 brew install nvm # 查看远程版本 nvm ls-remote # 安装制定版本号 nvm install v15.3.2 # 已经安装的版本号 nvm ls # 切换已经安装的版本号 nvm use 4.2
|
依赖管理
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| # 安装但不写入package.json; npm install xxx
# 安装并写入package.json的"dependencies"中 npm install xxx –S
# 安装并写入package.json的"devDependencies"中 npm install xxx –D
# 全局安装 npm install xxx -g
# 安装指定版本 npm install [email protected]
# 更新包 npm install -g npm-check-updates # 检查可更新的模块 ncu # 来更新package.json的依赖包到最新版本 ncu -u
|
node.js升级
1 2 3 4 5 6 7 8 9 10 11 12 13
| # 更新npm npm install -g npm
# 清空npm缓存 npm cache clean -f
# 安装n模块 npm install -g n
# 升级node.js到最新稳定版 n stable
# 有时候需要sudo权限,或者安装好了之后要开启一个新的shell才能用到新的版本
|
https://www.bilibili.com/video/BV1vE411871g?p=120
安装源
依赖升级
1 2 3
| npm install -g npm-upgrade npm-upgrade npm-upgrade <package>
|
ES6 & JS
字符串转数字
遍历2
排序
排序
join方法
遍历
foreach
1
| row.typeID.split(",").forEach(id=>{this.gameTypes.push(parseInt(id))})
|
NodJs项目部署到Vercel
1.创建node项目
2.安装依赖,package.json
1 2 3 4 5 6
| { "dependencies": { "@vercel/node": "^2.15.3", "express": "^4.18.2" } }
|
3.创建vercel.json
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| { "version": 2, "builds": [ { "src": "app.js", "use": "@vercel/node" } ], "routes": [ { "src": "/(.*)", "dest": "app.js" } ] }
|
4.创建app.js
1 2 3 4 5 6 7 8 9 10 11
| const express = require('express') const app = express() const port = 3000
app.get('/', (req, res) => { res.send('Hello World!') })
app.listen(port, () => { console.log(`Example app listening on port ${port}`) })
|
5.像平常部署别的项目一样,部署这个项目就可以,部署好之后,就能看到首页的Hello World!