123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 |
- {layout name="layout1" /}
- <div class="wrapper">
- <div class="layui-card">
- <div class="layui-card-body">
- <div class="layui-collapse like-layui-collapse" lay-accordion="" style="border:1px dashed #c4c4c4">
- <div class="layui-colla-item">
- <h2 class="layui-colla-title like-layui-colla-title" style="background-color: #fff">操作提示</h2>
- <div class="layui-colla-content layui-show">
- <p>1.请在linux环境使用crontab命令添加定时任务:*/1 * * * * php think crontab 。</p>
- <p>2.规则如下:</p>
- <p>*(0~59分) *(0~23小时) *(1~31号) *(1-12月) *(0-7星期,0和7都代表星期日)</p>
- <p>*(星号):代表任何时刻都接受的意思。例:0 10 * * * command 日、月、周都是*,就代表着不论何月、何日的星期几的10:00都执行后续命令的意思。</p>
- <p>,(逗号):代表分隔时段的意思。例:要执行的工作是2:00与3:00时,就会是:0 2,3 * * * command时间还是有五列,不过第二列是 2,3 ,代表2与3都适用。</p>
- <p>-(减号): 代表一段时间范围内,例:8点到11点之间的每小时的18分都进行一项工作:18 8-11 * * * command仔细看到第二列变成8-11.代表 8,9,10,11,12 都适用的。</p>
- <p>/n(斜线):那个n代表数字,即是每隔n单位间隔的意思,例:每五分钟进行一次,则:*/5 * * * * 。</p>
- </div>
- </div>
- </div>
- <br>
- <div style="padding-bottom: 10px;">
- <button class="layui-btn layui-btn-sm layuiadmin-btn-crontab {$view_theme_color}" data-type="add">添加</button>
- </div>
- <table id="crontab-lists" lay-filter="crontab-lists"></table>
- <script type="text/html" id="status">
- {{# if(d.status == 1){ }}
- <button class="layui-btn layui-btn-sm {$view_theme_button}">运行</button>
- {{# } }}
-
- {{# if(d.status == 2){ }}
- <button class="layui-btn layui-btn-sm layui-btn-danger">停止</button>
- {{# } }}
-
- {{# if(d.status == 3){ }}
- <button class="layui-btn layui-btn-sm layui-btn-danger">错误</button>
- {{# } }}
- </script>
- <script type="text/html" id="operation">
- <a class="layui-btn layui-btn-sm layui-btn-normal" lay-event="edit">编辑</a>
- {{# if(d.system == 0){ }}
- <a class="layui-btn layui-btn-sm layui-btn-danger" lay-event="delete">删除</a>
- {{# } }}
- {{# if(d.system == 1){ }}
- <a class="layui-btn layui-btn-sm layui-btn-danger layui-btn-disabled">删除</a>
- {{# } }}
- </script>
-
- </div>
- </div>
- </div>
- <script>
- layui.config({
- version:"{$front_version}",
- base: '/static/lib/' //静态资源所在路径
- }).use(['table'], function () {
- var $ = layui.$
- , form = layui.form
- , table = layui.table;
-
-
- table.render({
- elem: '#crontab-lists'
- , url: '{:url("system.Crontab/lists")}' //模拟接口
- , cols: [[
- {field: 'name', width: 150, title: '名称'}
- , {field: 'type_desc', width: 90, title: '类型'}
- , {field: 'command', width: 150, title: '命令'}
- , {field: 'parameter', width: 100, title: '参数'}
- , {field: 'expression', width: 100, title: '规则'}
- , {width:80,title: '状态', templet: '#status', align: 'center',sort: true}
- , {field: 'error', width: 120, title: '错误原因'}
- , {field: 'last_time_str', width: 160, title: '最后执行时间'}
- , {field: 'time', width: 90, title: '时长'}
- , {field: 'max_time', width: 90, title: '最大时长'}
- , {fixed: 'right', title: '操作',width: 300,align: 'center', toolbar: '#operation'}
- ]]
- , text: {none: '暂无数据!'}
- , parseData: function (res) { //将原始数据解析成 table 组件所规定的数据
- return {
- "code": res.code,
- "msg": res.msg,
- "count": res.data.count, //解析数据长度
- "data": res.data.lists, //解析数据列表
- };
- },
- response: {
- statusCode: 1
- }
- ,done: function(res, curr, count){
- // 解决操作栏因为内容过多换行问题
- $(".layui-table-main tr").each(function (index, val) {
- $($(".layui-table-fixed-l .layui-table-body tbody tr")[index]).height($(val).height());
- $($(".layui-table-fixed-r .layui-table-body tbody tr")[index]).height($(val).height());
- });
- }
- });
-
- //监听工具条
- table.on('tool(crontab-lists)', function (obj) {
- var operation = obj.event;
- var id = obj.data['id'];
- switch (operation) {
- case 'delete':
- layer.confirm('确定删除定时任务吗?', function(index){
- like.ajax({
- url:'{:url("system.Crontab/del")}',
- data:{'id':id},
- type:"post",
- success:function(res)
- {
- if(res.code == 1) {
- obj.del();
- layui.layer.msg(res.msg, {
- offset: '15px'
- , icon: 1
- , time: 1000
- });
- layer.close(index);
- }
- }
- });
- });
- break;
- case 'edit':
- layer.open({
- type: 2
- ,title: '编辑系统任务'
- ,content: '{:url("system.Crontab/edit")}?id='+id
- ,area: ['90%', '90%']
- ,btn: ['确定', '取消']
- ,yes: function(index, layero){
- var iframeWindow = window['layui-layer-iframe'+ index]
- ,submitID = 'crontab-submit-edit'
- ,submit = layero.find('iframe').contents().find('#'+ submitID);
- //监听提交
- iframeWindow.layui.form.on('submit('+ submitID +')', function(data){
- var field = data.field;
- like.ajax({
- url:'{:url("system.Crontab/edit")}',
- data:field,
- type:"post",
- success:function(res)
- {
- if(res.code == 1) {
- layui.layer.msg(res.msg, {
- offset: '15px'
- , icon: 1
- , time: 1000
- });
- layer.close(index); //关闭弹层
- table.reload('crontab-lists'); //数据刷新
- }
- }
- });
- });
- submit.trigger('click');
- }
- })
- }
- });
-
- var active = {
- add: function(){
- layer.open({
- type: 2
- ,title: '添加系统任务'
- ,content: '{:url("system.Crontab/add")}'
- ,area: ['90%', '90%']
- ,btn: ['确定', '取消']
- ,yes: function(index, layero){
- var iframeWindow = window['layui-layer-iframe'+ index]
- ,submitID = 'crontab-submit'
- ,submit = layero.find('iframe').contents().find('#'+ submitID);
- //监听提交
- iframeWindow.layui.form.on('submit('+ submitID +')', function(data){
- var field = data.field;
- like.ajax({
- url:'{:url("system.Crontab/add")}',
- data:field,
- type:"post",
- success:function(res)
- {
- if(res.code == 1) {
- layui.layer.msg(res.msg, {
- offset: '15px'
- , icon: 1
- , time: 1000
- });
- layer.close(index); //关闭弹层
- table.reload('crontab-lists'); //数据刷新
- }
- }
- });
- });
-
- submit.trigger('click');
- }
- });
- },
- }
- $('.layui-btn.layuiadmin-btn-crontab').on('click', function(){
- var type = $(this).data('type');
- active[type] ? active[type].call(this) : '';
- });
- });
- </script>
|