layui 相关
//layui table filter 监听筛选列工具条的点击事件(解决table右上角筛选时列名称不显示问题)
table.on('toolbar(currentTableFilter)', function(obj){
if(obj.event === 'LAYTABLE_COLS'){// 筛选列按钮被点击
// 获取下拉面板元素
var panel = $(obj.config.elem).find('.layui-table-tool-panel');
console.log('abc', $('.layui-table-tool-panel').html(), $(obj.config.elem), panel.html())
$('.layui-table-tool-panel>li').each(function(index,dom){
$(dom).find('div>div').replaceWith(function() {
return "<span>" + this.innerHTML + "</span>";
});
});
}
});
/**解决layui 列表中swich 按钮结构为div时的样式问题 start **/
.layui-form-switch div {
position: relative;
top: 0;
width: 25px;
margin-left: 21px;
padding: 0!important;
text-align: center!important;
color: #999!important;
font-style: normal!important;
font-size: 12px
}
.layui-form-onswitch div {
margin-left: 0;
margin-right: 21px;
color: #fff!important
}
.layui-checkbox-disabled div {
color: #d2d2d2!important
}
/**解决layui 列表中swich 按钮结构为div时的样式问题 end **/
通过js解决:
layui table函数中添加:
done: function(res, curr, count, origin){
$('.layui-form-switch>div').each(function(index,dom){
$(dom).replaceWith(function() {
return "<em>" + this.innerHTML + "</em>";
});
});
},
1、layui上传图片封装js
//工具函数 function Tools(){ } Tools.prototype = { moneyFormat : function(val,decimals= 2){ let formattedNumber = val.toFixed(decimals); // 将数字保留2位小数 //console.log(formattedNumber); // 输出 "0.00" return formattedNumber; }, /** * 上传图片 * @param upload layui中的upload对象,比如: upload=layui.upload, * @param idSelector 上传按钮的id值 * @param filePath 上传后需要图片存储的路径 */ uploadImg: function({upload,element}, idSelector, filePath){ var uploadInst = upload.render({ elem: '#'+idSelector, url: '/admin/upload/img', // 此处用的是第三方的 http 请求演示,实际使用时改成您自己的上传接口即可。 data:{path: (typeof(filePath) == 'undefined' ? 'uploadfile/others' : filePath) }, field:'file', acceptMime: 'image/jpeg, image/png', // 只筛选 jpg,png 格式图片 accept:'images', //指定允许上传时校验的文件类型 exts:'jpg|png|jpeg', //允许上传的文件后缀。一般结合 accept 属性来设定。 before: function(obj){ var that = this; // 预读本地文件示例,不支持ie8 obj.preview(function(index, file, result){ $(that.item).parent().find('.cls-upload-img').attr('src', result); // 图片链接(base64) }); var sourceId = $(this.item).attr('id'); if(element && (typeof element != undefined)){ element.progress('filter-demo'+sourceId, '0%'); // 进度条复位 } layer.msg('上传中', {icon: 16, time: 0}); }, done: function(res,index,upload){ if(res.code > 0){// 若上传失败 return layer.msg('上传失败'); } // 上传成功的一些操作 $(this.item).parent().find('.cls-upload-text').html(''); // 置空上传失败的状态 $('input[name="image"]').val(res.data.file_path); }, error: function(index,upload){ // 演示失败状态,并实现重传 var demoText = $(this.item).parent().find('.cls-upload-text'); demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>'); demoText.find('.demo-reload').on('click', function(){ uploadInst.upload(); }); }, progress: function(n, elem, e){ // 进度条 var sourceId = $(this.item).attr('id'); if(element && (typeof element != undefined)){ element.progress('filter-demo'+sourceId, n + '%'); // 可配合 layui 进度条元素使用 } if(n == 100){ layer.msg('上传完毕', {icon: 1}); } } }); } }; var tools = new Tools();
2、layui 上传图片html代码:
<div class="layui-form-item"> <input type="hidden" name="image" lay-verify="required" lay-reqtext="请上传KV图片"> <label class="layui-form-label required">KV图片:</label> <div class="layui-input-block"> <button type="button" class="layui-btn" id="upload-cover-btn"> <i class="layui-icon layui-icon-addition"><!--上传--></i> </button> <div style="width: 90%"> <div class="layui-upload-list"> <img class="layui-upload-img cls-upload-img" id="upload-cover-img" style="width:400px;height: 200px;"> <div id="upload-cover-text" class="cls-upload-text"></div> </div> {{-- <div class="layui-progress layui-progress-big" lay-showPercent="yes" lay-filter="filter-demoupload-cover-btn">--}} {{-- <div class="layui-progress-bar" lay-percent=""></div>--}} {{-- </div>--}} </div> </div> </div>
3、layui 上传图片html中调用js封装的方法
layui.use(['form','tableSelect','upload','layer'], function () { var form = layui.form, layer = layui.layer, $ = layui.$, upload=layui.upload, tableSelect = layui.tableSelect; var element = layui.element; tools.uploadImg({upload}, 'upload-cover-btn', 'uploadfile/admin/news');
判断列表后面的操作按钮的显示隐藏:
<script type="text/html" id="barDemo"> <a class="layui-btn layui-btn-mini" lay-event="look">查看</a> @{{# if(d.status ==0){ }} <a class="layui-btn layui-btn-mini" lay-event="edit">编辑</a> @{{# }if(d.status ==1) { }} <a class="layui-btn layui-btn-mini" lay-event="submit">提交</a> @{{# }if(d.status ==2) { }} <a class="layui-btn layui-btn-danger layui-btn-mini" lay-event="del">删除</a> @{{# } }} </script> demo2: <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter0"></table> <script type="text/html" id="currentTableBar"> {{-- <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">操作</a>--}} @{{# if(d.status ==0){ }} <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="pass" >通过</a> <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="refuse" >不通过</a> @{{# } }} {{-- <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="remove_auth">解绑</a>--}} </script>
在layui layer 弹出层中加载 layui table
layui table 回显数据设置默认选中 , 是否可以设置默认选中多个不连续的行:
你可以通过为每一条需要默认选中的数据设置 LAY_CHECKED: true
来实现默认选中多个不连续的行。举个例子:
layui.use('table', function(){ var table = layui.table; table.render({ elem: '#test' ,data: [ {id: 1, name: '行1', age: 1, LAY_CHECKED: true}, //这条记录的 LAY_CHECKED 设置为 true,表示默认选中 {id: 2, name: '行2', age: 2}, {id: 3, name: '行3', age: 3, LAY_CHECKED: true}, //这条记录的 LAY_CHECKED 设置为 true,表示默认选中 {id: 4, name: '行4', age: 4}, {id: 5, name: '行5', age: 5, LAY_CHECKED: true} //这条记录的 LAY_CHECKED 设置为 true,表示默认选中 ] ,cols: [[ {checkbox: true}, {field: 'id', title: 'ID'}, {field: 'name', title: '名称'}, {field: 'age', title: '年龄'} ]] ,even: true }); });
在上述代码中,id
为 1、3 和 5 的行将在页面加载时默认为选中状态。这也是通过在每一个需要选中的行数据中设置 LAY_CHECKED: true
来达到的目的。
posted on 2023-10-08 13:37 andydaopeng 阅读(36) 评论(0) 编辑 收藏 举报