This commit is contained in:
贤心
2023-04-24 08:42:47 +08:00
parent 0172797f79
commit 5a386e3124
154 changed files with 23579 additions and 0 deletions

127
docs/util/detail/demo.md Normal file
View File

@@ -0,0 +1,127 @@
<pre class="layui-code" lay-options="{preview: true, codeStyle: 'height: 535px;', layout: ['preview', 'code'], tools: ['full']}">
<textarea>
<h3 class="ws-anchor ws-bold">倒计时</h3>
请选择要计算的日期:
<div class="layui-inline">
<input type="text" readonly class="layui-input" id="test1" value="2099-12-31 00:00:00">
</div>
<blockquote class="layui-elem-quote" style="margin-top: 10px;">
<div id="test2"></div>
</blockquote>
<h3 class="ws-anchor ws-bold">某个时间在多久前</h3>
请选择要计算的日期:
<div class="layui-inline">
<input type="text" readonly class="layui-input" id="test3">
</div>
<span class="layui-word-aux" id="test4"></span>
<h3 class="ws-anchor ws-bold">转换日期格式</h3>
请编辑格式:
<div class="layui-inline">
<input type="text" value="yyyy-MM-dd HH:mm:ss" class="layui-input" id="test5">
</div>
<span class="layui-word-aux" id="test6"></span>
<h3 class="ws-anchor ws-bold">转义 HTML</h3>
<div class="layui-form">
&lt;textarea class="layui-textarea" id="test7"&gt;
<h3>HTML Title</h3>
&lt;script&gt;
alert(0);
&lt;/script&gt;
&lt;/textarea&gt;
</div>
<div class="layui-btn-container" style="margin-top: 10px;">
<button class="layui-btn" lay-on="escape">转义</button>
<button class="layui-btn" lay-on="unescape">还原</button>
</div>
<script>
layui.use(function(){
var util = layui.util;
var laydate = layui.laydate;
var layer = layui.layer;
var $ = layui.$;
// 倒计时
var thisTimer;
var setCountdown = function(value){
var endTime = new Date(value); // 结束日期
var serverTime = new Date(); // 假设为当前服务器时间,这里采用的是本地时间,实际使用一般是取服务端的
clearTimeout(thisTimer);
util.countdown(endTime, serverTime, function(date, serverTime, timer){
var str = date[0] + ' 天 ' + date[1] + ' 时 ' + date[2] + ' 分 ' + date[3] + ' 秒';
lay('#test2').html('距离上述日期还有:'+ str);
thisTimer = timer;
});
};
setCountdown('2099-12-31 00:00:00');
laydate.render({
elem: '#test1',
type: 'datetime',
done: function(value, date){
setCountdown(value);
}
});
// 某个时间在多久前
var setTimeAgo = function(y, M, d, H, m, s){
var str = util.timeAgo(new Date(y, M||0, d||1, H||0, m||0, s||0));
lay('#test4').html(str);
};
laydate.render({
elem: '#test3',
type: 'datetime',
done: function(value, date){
setTimeAgo(
date.year,
date.month - 1,
date.date,
date.hours,
date.minutes,
date.seconds
);
}
});
// 转换日期格式
var toDateString = function(format){
var dateString = util.toDateString(new Date(), format); // 执行转换日期格式的方法
$('#test6').html(dateString);
};
toDateString($('#test5').val());
// 输入框事件
$('#test5').on('input propertychange', function(){
toDateString(this.value);
});
// HTML 转义
util.event('lay-on', {
escape: function(){ // 转义
var textarea = $('#test7');
var value = textarea.val();
var str = util.escape(value); // 执行转义方法
textarea.val(str);
},
unescape: function(){
var textarea = $('#test7');
var value = textarea.val();
var str = util.unescape(value); // 执行转义方法
textarea.val(str);
}
});
});
</script>
</textarea>
</pre>

180
docs/util/index.md Normal file
View File

@@ -0,0 +1,180 @@
---
title: 工具模块 util
toc: true
---
# 工具模块
> 工具模块 `util` 是由工具类方法和小组件组成的集合。
<h2 id="examples" lay-toc="{hot: true}" style="margin-bottom: 0;">示例</h2>
<div>
{{- d.include("docs/util/detail/demo.md") }}
</div>
<p></p>
<h2 id="api" lay-toc="{hot: true}">API</h2>
| API | 描述 |
| --- | --- |
| var util = layui.util | 获得 `util` 模块。 |
| util.fixbar(options) | `fixbar` 固定条组件,用法:[#详见](../fixbar/) |
| [util.countdown(endTime, serverTime, callback)](#countdown) | 倒计时 |
| [util.timeAgo(time, onlyDate)](#timeAgo) | 某个时间在多久前 |
| [util.toDateString(time, format)](#toDateString) | 将毫秒数或日期对象转换成日期格式字符 |
| [util.digit(num, length)](#digit) | 数字前置补零 |
| [util.escape(str)](#escape) | 转义 HTML 字符 |
| [util.unescape(str)](#escape) | 还原 HTML 字符 |
| [util.openWin(options)](#openWin) <sup>2.8+</sup> | 打开浏览器新标签页 |
| [util.on(attr, obj, eventType)](#on) | 批量事件处理 |
<h3 id="countdown" class="ws-anchor ws-bold">倒计时</h3>
`util.countdown(endTime, serverTime, callback);`
- 参数 `endTime` : 结束时间毫秒数或 `Date` 对象
- 参数 `serverTime` : 服务器当前时间毫秒数 或 `Date` 对象
- 参数 `callback` : 倒计时回调函数。若倒计时正在运行,则每一秒都会执行一次。并且返回以下三个参数。
- `date` 包含天/时/分/秒的对象
- `serverTime` 当前服务器时间毫秒数或 `Date` 对象
- `timer` 计时器返回的索引,用于 `clearTimeout`
该方法并不负责视图的呈现,而仅返回倒计时数值。 相关用法见:[#示例](#examples)
```
layui.use('util', function(){
var util = layui.util;
// 示例
var endTime = new Date(2099,1,1).getTime() // 假设为结束日期
var serverTime = new Date().getTime(); // 这里采用的是本地时间,实际使用一般是取服务端时间
util.countdown(endTime, serverTime, function(date, serverTime, timer){
console.log(date, serverTime, timer)
});
});
```
<h3 id="timeAgo" class="ws-anchor ws-bold">某个时间在多久前</h3>
`var result = util.timeAgo(time, onlyDate);`
- 参数 `time` : 某个时间的毫秒数或日期对象
- 参数 `onlyDate` : 是否在超过 30 天后,只返回日期字符,而不返回时分秒
返回结果
-`time` 在 3 分钟以内,返回: 刚刚
-`time` 在 30 天以内,返回: 若干分钟前、若干小时前、若干天前5 分钟前
-`time` 在 30 天以上,返回: 日期字符,如: 2023-01-01
```
var result = util.timeAgo(1672531200000); // 2023-01-01 00:00:00
```
相关效果见:[#示例](#examples)
<h3 id="toDateString" class="ws-anchor ws-bold">转换日期格式字符</h3>
`var result = util.toDateString(time, format);`
- 参数 `time` : 毫秒数或日期对象
- 参数 `format` : 日期字符格式。默认格式:`yyyy-MM-dd HH:mm:ss` 。可自定义,如: `yyyy年MM月dd日`
```
var result = util.toDateString(1672531200000, 'yyyy-MM-dd'); // 2023-01-01
```
<h3 id="digit" class="ws-anchor ws-bold">数字前置补零</h3>
`util.digit(num, length);`
- 参数 `num` : 原始数字
- 参数 `length` : 数字长度,如果原始数字长度小于 length则前面补零
该方法返回一个 `string` 类型的结果,如:
```
var rs1 = util.digit(6, 2); // "06"
var rs2 = util.digit(7, 3); // "007"
```
<h3 id="escape" class="ws-anchor ws-bold">转义和还原 HTML</h3>
- `util.escape(str);` 转义 HTML
- `util.unescape(str);` 还原被转义的 HTML
参数 `str` : 任意 HTML 字符
```
var str1 = util.escape('<div>123</div>'); // 返回: &lt;div&gt;123&lt;/div&gt;
var str2 = util.unescape('&lt;div&gt;123&lt;/div&gt;'); // 返回: <div>123</div>
```
<h3 id="openWin" class="ws-anchor ws-bold">打开浏览器新标签页 <sup>2.8+</sup></h3>
`util.openWin(options);`
- 参数 `options` : 属性配置项。可选项详见下表
| 属性 | 描述 |
| --- | --- |
| url | 要打开页面 `URL` |
| target | 打开页面的方式或窗口 `name` |
| content | 打开的页面内容。若设置了 `url` 属性,则该属性无效 |
| specs | 窗口的相关配置,同 `window.open()``specs` |
| window | 当前所在的窗口对象,默认 `self` |
该方法基于原生 `window.open()` 的二次封装,以提升打开浏览器窗口的灵活性。
```
// 打开一个 url
util.openWin({
url: 'https://cn.bing.com'
});
// 打开一个自定义内容窗口
util.openWin({
content: 'Hello World.'
});
```
<h3 id="on" class="ws-anchor ws-bold">批量事件处理</h3>
`util.on(attr, obj, eventType);`
- 参数 `attr` : 触发事件的元素属性名
- 参数 `obj` : 事件回调函数集合
- 参数 `eventType` : 事件类型。默认 `click`
<pre class="layui-code" lay-options="{preview: true, codeStyle: 'height: 535px;', layout: ['code', 'preview'], tools: ['full']}">
<textarea>
<div class="layui-btn-container">
<button class="layui-btn" lay-on="e1">事件 1</button>
<button class="layui-btn" lay-on="e2">事件 2</button>
<button class="layui-btn" lay-on="e3">事件 3</button>
</div>
<script>
layui.use('util', function(){
var util = layui.util;
// 处理属性 为 lay-on 的所有元素事件
util.on('lay-on', {
e1: function(){
console.log(this); // 当前触发事件的 DOM 对象
layer.msg('触发了事件 1');
},
e2: function(){
layer.msg('触发了事件 2');
},
e3: function(){
layer.msg('触发了事件 3');
}
});
});
</script>
</textarea>
</pre>