Files
layui/examples/base.html
sunxiaobin89 5ab142153b ci: 添加 lint 和 format 工具,统一代码格式 (#2905)
* style: 统一代码格式,修复ESLint错误

- 为所有模块添加尾随逗号
- 修复缺少分号的语句
- 统一对象字面量格式
- 添加ESLint配置文件和文档
- 更新package.json中的脚本和依赖项

* build: 添加 ESLint 配置文件以支持 IE9+ 兼容性

* refactor(upload): 使用已缓存的hint实例替换直接调用

优化代码性能,避免重复实例化hint对象,直接使用模块顶部已缓存的实例

* chore: 更新.gitignore文件以包含更多忽略规则

添加了更多常见的临时文件、编辑器文件、构建输出目录和运行时数据的忽略规则,使项目更加整洁并避免不必要的文件被提交到版本控制中

* fix(lay.js): 修复passive事件监听器选项的返回值

确保getter函数返回true以正确支持passive事件监听

* refactor(form): 移除表单模块中的冗余代码

删除表单模块中无实际作用的冗余代码行,这些代码只是将属性重新赋值为自身,没有实际功能意义

* fix(form): 修复复选框状态处理逻辑

确保复选框的 indeterminate 和 checked 状态被正确转换为布尔值,并优化事件调用时的空格格式

* feat(eslint): 完善 ESLint 配置并添加 VSCode 支持

添加 VSCode 配置文件以支持 ESLint 自动修复和格式化
更新 ESLint 配置,增强代码风格和兼容性规则
修复 package.json 中的脚本拼写错误并添加 format 脚本
调整 .gitignore 以允许特定 VSCode 配置文件

* style: 统一代码中的引号格式并修复缩进问题

统一将双引号改为单引号,修复部分代码缩进不一致的问题,提升代码风格一致性

* docs: 删除过时的ESLint配置文档文件

* build: 采用 prettier 作为代码格式化工具,剔除 ESLint 格式化部分

* chore: 剔除 .vscode/ 配置,保持编辑器中立

* build: 修改 ESLint 为「扁平化配置」方式,避免大量参数堆砌

* chore: 格式化代码

* ci: 添加 git hooks 和 CI 环节把关代码风格

* ci: update

* ci: update

* test: 测试 ci format

* ci: 改用 husky 作为 git hooks,与 Layui 3 保持一致

经测试,simple-git-hooks 生成的 pre-commit 默认为 sh,在 Windows 不兼容(必须用 git bash 执行 commits)

* build: 新增 CI 和生产环境跳过 husky 安装的判断

* build: 剔除重复配置

* build: 优化 eslint 配置

---------

Co-authored-by: 贤心 <3277200+sentsim@users.noreply.github.com>
2025-11-10 16:03:37 +08:00

478 lines
12 KiB
HTML

<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>基础方法测试 - layui</title>
<link href="../src/css/layui.css" rel="stylesheet" />
<link href="./test/test.css" rel="stylesheet" />
</head>
<body>
<div class="layui-panel test-side">
<ul class="layui-menu">
<li>
<div class="layui-menu-body-title">
<a href="#layui.sort">layui.sort</a>
</div>
</li>
<li>
<div class="layui-menu-body-title">
<a href="#layui.type">layui.type</a>
</div>
</li>
<li>
<div class="layui-menu-body-title">
<a href="#layui.isArray">layui.isArray</a>
</div>
</li>
<li>
<div class="layui-menu-body-title">
<a href="#lay.extend">lay.extend</a>
</div>
</li>
<li>
<div class="layui-menu-body-title">
<a href="#lay.treeToFlat">lay.treeToFlat</a>
</div>
</li>
<li>
<div class="layui-menu-body-title">
<a href="#lay.flatToTree">lay.flatToTree</a>
</div>
</li>
</ul>
</div>
<div class="test-main">
<div id="tests"></div>
</div>
<script src="../src/layui.js"></script>
<script>
layui.use(async function () {
var lay = layui.lay;
var util = layui.util;
// 导入测试模块
const { test } = await import('./test/test.js');
const tester = test();
tester.describe('layui.sort', function (it) {
it({
title: '整数型数字排序',
code: `
const arr = layui.sort([{a: 3},{a: 0},{a: 0},{a: -1},{a: -5},{a: 6},{a: 9},{a: -333333}], 'a');
console.log(arr);
`,
expected: [
{ a: -333333 },
{ a: -5 },
{ a: -1 },
{ a: 0 },
{ a: 0 },
{ a: 3 },
{ a: 6 },
{ a: 9 }
]
});
it({
title: '浮点型数字排序',
code: `
const arr = layui.sort([{a: 3.5},{a: 0.5},{a: 0.5},{a: -1.5},{a: -5.5},{a: 6.5},{a: 9.5},{a: -333333.5}], 'a');
console.log(arr);
`,
expected: [
{ a: -333333.5 },
{ a: -5.5 },
{ a: -1.5 },
{ a: 0.5 },
{ a: 0.5 },
{ a: 3.5 },
{ a: 6.5 },
{ a: 9.5 }
]
});
it({
title: '混合型数字排序',
code: `
const arr = layui.sort([{a: 1},{a: 20.5},{a: 20.3},{a: 3},{a: 52},{a: 4.3}], 'a');
console.log(arr);
`,
expected: [
{ a: 1 },
{ a: 3 },
{ a: 4.3 },
{ a: 20.3 },
{ a: 20.5 },
{ a: 52 }
]
});
it({
title: '中文排序',
code: `
const arr = layui.sort([{a: '男'},{a: '女'},{a: '男'},{a: '女'},{a: '男'}], 'a');
console.log(arr);
`,
expected: [
{ a: '女' },
{ a: '女' },
{ a: '男' },
{ a: '男' },
{ a: '男' }
]
});
it({
title: '英文排序',
code: `
const arr = layui.sort([{a: 'E'},{a: 'B'},{a: 'D'},{a: 'C'},{a: 'A'}], 'a');
console.log(arr);
`,
expected: [
{ a: 'A' },
{ a: 'B' },
{ a: 'C' },
{ a: 'D' },
{ a: 'E' }
]
});
it({
title: '混合排序',
code: `
const arr = layui.sort([
{a: 3},
{a: '男'},
{a: 0},
{a: 66},
{a: 99},
{a: 'C'},
{a: '女'},
{a: 3.5},
{a: 0},
{a: -1},
{a: 'B'},
{a: 5.5},
{a: '男'},
{a: 'A'},
{a: -5},
{a: '男'},
{a: 6},
{a: 9}
], 'a');
console.log(arr);
`,
expected: [
{ a: -5 },
{ a: -1 },
{ a: 0 },
{ a: 0 },
{ a: 3 },
{ a: 3.5 },
{ a: 5.5 },
{ a: 6 },
{ a: 9 },
{ a: 66 },
{ a: 99 },
{ a: 'A' },
{ a: 'B' },
{ a: 'C' },
{ a: '女' },
{ a: '男' },
{ a: '男' },
{ a: '男' }
]
});
it({
title: '数组成员为纯数字',
code: `
const arr = layui.sort([1, 20.5, 19.5, 52, 4.5]);
console.log(arr);
`,
expected: [1, 4.5, 19.5, 20.5, 52]
});
it({
title: '数组成员为混合型',
code: `
// 按成员对象的 key 为 a 进行比较
const arr = layui.sort([1, {a: 32}, 20.5, {a: 6}, 52, 5.5], 'a');
console.log(arr);
`,
expected: [1, 5.5, { a: 6 }, 20.5, { a: 32 }, 52]
});
});
tester.describe('layui.type', function (it) {
it({
title: 'new RegExp()',
code: `console.log(layui.type(new RegExp()))`,
expected: 'regexp'
});
it({
title: 'new Date()',
code: `console.log(layui.type(new Date()))`,
expected: 'date'
});
});
tester.describe('layui.isArray', function (it) {
it({
title: '[]',
code: `console.log(layui.isArray([]))`,
expected: true
});
it({
title: 'lay("div")',
code: `console.log(layui.isArray(lay("div")))`,
expected: true
});
it({
title: 'document.querySelectorAll("div")',
code: `console.log(layui.isArray(document.querySelectorAll("div")))`,
expected: true
});
it({
title: '{}',
code: `console.log(layui.isArray({}))`,
expected: false
});
});
tester.describe('lay.extend', function (it) {
const objNCode = `
const objN = [
{
a: [1, 3],
b: {ba: 1}
},
{
a: [5],
b: {bb: 2}
},
{
b: {ba: 3},
c: 3
}
];
`;
it({
title: '普通拷贝',
code: `
const obj = lay.extend({}, {a:1});
console.log(obj);
`,
expected: { a: 1 }
});
it({
title: '普通合并',
code: `
const obj = lay.extend({a:1}, {a:3}, {a:5, b:5});
console.log(obj);
`,
expected: { a: 5, b: 5 }
});
it({
title: '值为「普通对象和数组」的深拷贝合并',
code: `
${objNCode}
const obj = lay.extend({}, ...objN);
console.log(obj);
`,
expected: { a: [5, 3], b: { ba: 3, bb: 2 }, c: 3 }
});
it({
title: '使用 customizer 实现数组覆盖而非合并',
code: `
${objNCode}
const obj = lay.extend({}, ...objN, (objValue, srcValue) => {
if (Array.isArray(objValue) && Array.isArray(srcValue)) {
return srcValue
// 若为 Object[] 值,可深拷贝数据源覆盖
// return lay.extend([], srcValue);
}
});
console.log(obj);
`,
expected: { a: [5], b: { ba: 3, bb: 2 }, c: 3 }
});
it({
title: '使用 customizer 实现特定字段跳过合并',
code: `
${objNCode}
const obj = lay.extend({}, ...objN, (objValue, srcValue, key) => {
if (key === 'b') {
return objValue;
}
});
console.log(obj);
`,
expected: { a: [5, 3], b: { ba: 1 }, c: 3 }
});
it({
title: '是否存在对象引用',
code: `
const src = { data: [{a: 1, b: 2}] };
const obj = lay.extend({}, src);
// 修改 obj 数组类型中的对象成员,查看 src 是否被影响
obj.data[0].a = '11111';
console.log(obj.data[0].a === src.data[0].a);
`,
expected: false
});
});
tester.describe('lay.treeToFlat', function (it) {
const data = [
{
title: '节点 1',
id: '1000',
children: [
{
title: '节点 1-1',
id: '1001'
},
{
title: '节点 1-2',
id: '1002',
children: [
{
title: '节点 1-2-1',
id: '1003'
}
]
}
]
},
{
title: '节点 2',
id: '2000'
}
];
it({
title: '树状数据展平',
code: `
const data = ${JSON.stringify(data, null, 2)};
// 树状数据展平
const flatData = lay.treeToFlat(data, {
keepChildren: true // 是否保留 children 字段
});
console.log(JSON.stringify(flatData));
`,
expected: '子节点被展平到一级数组中(控制台查看)',
assert(actual, expected) {
try {
actual = JSON.parse(actual);
console.log(`${this.title} : `, actual);
return actual.length === 5;
} catch (e) {
return false;
}
}
});
it({
title: '是否存在对象引用',
code: `
const data = ${JSON.stringify(data, null, 2)};
// 树状数据展平
const flatData = lay.treeToFlat(data, {
keepChildren: true // 是否保留 children 字段
});
flatData[0].children[0].title="333333"; // 修改数据
console.log(flatData[0].children[0].title === data[0].children[0].title);
`,
expected: false
});
});
tester.describe('lay.flatToTree', function (it) {
const data = [
{
title: '节点 1',
id: '1000',
parentId: null
},
{
title: '节点 1-1',
id: '1001',
parentId: '1000'
},
{
title: '节点 1-2',
id: '1002',
parentId: '1000'
},
{
title: '节点 1-2-1',
id: '1003',
parentId: '1002'
},
{
title: '节点 2',
id: '2000',
parentId: null
}
];
it({
title: '平铺数据转树状',
code: `
const data = ${JSON.stringify(data, null, 2)};
const treeData = lay.flatToTree(data); // 平铺数据转树状
console.log(JSON.stringify(treeData));
`,
expected: '根据 parentId 字段进行树状数据生成(控制台查看)',
assert(actual, expected) {
try {
actual = JSON.parse(actual);
console.log(`${this.title} : `, actual);
return actual.length === 2;
} catch (e) {
return false;
}
}
});
it({
title: '是否存在对象引用',
code: `
const data = ${JSON.stringify(data, null, 2)};
const treeData = lay.flatToTree(data); // 平铺数据转树状
treeData[0].children[0].title="333333"; // 修改数据
// 查看原始数据是否被修改
console.log(treeData[0].children[0].title === data[1].title);
`,
expected: false
});
});
// 统计结果
tester.stats();
// 返回顶部
util.fixbar();
});
</script>
</body>
</html>