Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
檀越@新空间
Coding Tree
提交
b6e701c9
C
Coding Tree
项目概览
檀越@新空间
/
Coding Tree
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
Coding Tree
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
b6e701c9
编写于
5月 30, 2022
作者:
彭世瑜
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix
上级
49f1c9cc
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
170 addition
and
2 deletion
+170
-2
blog/php-mysql/index.md
blog/php-mysql/index.md
+1
-1
blog/webpack/webpack-loader.md
blog/webpack/webpack-loader.md
+169
-1
未找到文件。
blog/php-mysql/index.md
浏览文件 @
b6e701c9
...
...
@@ -38,7 +38,7 @@
18.
[
高级数据操作-查询数据
](
blog/php-mysql/sql-senior-select.md
)
[
查询中的运算符
](
blog/php-mysql/sql-operator.md
)
19.
[
查询中的运算符
](
blog/php-mysql/sql-operator.md
)
[
联合查询 union
](
blog/php-mysql/sql-union.md
)
...
...
blog/webpack/webpack-loader.md
浏览文件 @
b6e701c9
...
...
@@ -274,10 +274,178 @@ this.utils.absolutify |返回一个绝对路径 |this.utils.absolutify(context,
### clean-log-loader
去除
`console.log`
语句
```
js
// console-log-laoder.js
module
.
exports
=
function
(
content
,
map
,
meta
)
{
return
content
.
replace
(
/console
\.
log
\(
.*
\)
;
?
/g
,
''
);
};
```
https://www.bilibili.com/video/BV14T4y1z7sw?p=67&spm_id_from=pageDriver
使用
```
js
// webpack.config.js
module
.
exports
=
{
module
:
{
rules
:
[
{
test
:
/
\.
js$/
,
loader
:
"
./loaders/console-log-laoder.js
"
,
},
],
},
};
```
### banner-loader
给内容中增加一个作者信息
```
js
// banner-loader/index.js
const
schema
=
require
(
"
./schema.json
"
);
module
.
exports
=
function
(
content
,
map
,
meta
)
{
// schema对options进行规则校验
const
options
=
this
.
getOptions
(
schema
);
const
prefix
=
`
/**
* Author:
${
options
.
author
}
**/
`
;
return
prefix
+
content
;
};
```
参数验证规则 banner-loader/schema.json
```
json
{
"type"
:
"object"
,
"properties"
:
{
"author"
:
{
"type"
:
"string"
}
},
"additionalProperties"
:
false
}
```
说明:
```
json
//
是否允许额外的属性
"additionalProperties"
:
false
```
使用
```
js
// webpack.config.js
module
.
exports
=
{
module
:
{
rules
:
[
{
test
:
/
\.
js$/
,
loader
:
"
./loaders/banner-loader/index.js
"
,
options
:
{
author
:
"
曹操
"
},
},
],
},
};
```
### babel-loader
自定义babel-loader,转换ES6语法
```
bash
npm i
-D
@babel/preset-env @babel/core
```
```
js
// babel-loader/index.js
const
babel
=
require
(
"
@babel/core
"
);
const
schema
=
require
(
"
./schema.json
"
);
// https://www.babeljs.cn/docs/babel-core
module
.
exports
=
function
(
content
,
map
,
meta
)
{
// 异步loader
const
callback
=
this
.
async
();
// schema对options进行规则校验
const
options
=
this
.
getOptions
(
schema
);
// 使用babel 对代码进行编译
babel
.
transform
(
content
,
options
,
function
(
err
,
result
)
{
if
(
err
)
{
callback
(
err
);
}
else
{
callback
(
null
,
result
.
code
);
}
});
};
```
参数校验规则 babel-loader/schema.json
```
json
{
"type"
:
"object"
,
"properties"
:
{
"presets"
:
{
"type"
:
"array"
}
},
"additionalProperties"
:
true
}
```
入口文件
```
js
// src/index.js
function
sum
(...
args
)
{
return
args
.
reduce
((
x
,
y
)
=>
x
+
y
,
0
);
}
```
使用
```
js
// webpack.config.js
module
.
exports
=
{
module
:
{
rules
:
[
{
test
:
/
\.
js$/
,
loader
:
"
./loaders/babel-loader/index.js
"
,
options
:
{
presets
:
[
'
@babel/preset-env
'
],
},
},
],
}
};
```
https://www.bilibili.com/video/BV14T4y1z7sw?p=74&spm_id_from=pageDriver
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录