页面前端切换tab风格

1.html页面的源码


@layout("/common/_container.html",{js:["/assets/js/jbrTradeorder/jbrTradeorder.js"]}){

<div class="layui-body-header">
    <span class="layui-body-header-title">运单表配载管理</span>
</div>

<div class="layui-fluid">

    <div class="layui-row layui-col-space15">
        <div class="layui-col-sm12 layui-col-md12 layui-col-lg12">
            <div class="layui-card">
                <div class="layui-card-body">
                    <div class="layui-form">
                        <div class="layui-form-item layui-col-sm12 layui-col-md12 layui-col-lg12">
                            <div class="layui-inline">
                                <label class="layui-form-label">关键字</label>
                                <div class="layui-input-inline">
                                    <input id="keywords" class="layui-input" style="width: auto" type="text" placeholder="收,寄件人信息"/>
                                </div>
                            </div>

                            <div class="layui-inline">
                                <label class="layui-form-label">创建时间范围</label>
                                <div class="layui-input-inline">
                                    <input type="text" class="layui-input" id="queryCreatTime">
                                </div>
                            </div>
                            <div class="layui-inline">
                                <label class="layui-form-label">车辆</label>
                                <div class="layui-input-inline" style="width:100px">
                                    <select name="queryCar" >
                                        <option value=""></option>
                                        @if(isNotEmpty(carList)){
                                        @for( car in carList ){
                                        <option value="${car.id}">${car.carDriver!}</option>
                                        @}
                                        @}
                                    </select>
                                </div>
                            </div>

                            <div class="layui-inline">
                                <label class="layui-form-label">线路</label>
                                <div class="layui-input-inline" style="width:100px">
                                    <select name="queryRoad" >
                                        <option value=""></option>
                                        @if(isNotEmpty(xgRoadList)){
                                        @for( xgRoad in xgRoadList ){
                                        <option value="${xgRoad.id}">${xgRoad.rTitle!}</option>
                                        @}
                                        @}
                                    </select>
                                </div>
                            </div>

                            <div class="layui-inline">
                                <label class="layui-form-label">开单员</label>
                                <div class="layui-input-inline" style="width:120px">
                                    <select class="layui-col-md1" id="queryUser" name="queryUser" >
                                        <option value=""></option>
                                        @if(isNotEmpty(userList)){
                                        @for( user in userList ){
                                        <option value="${user.userId}">${user.name!}</option>
                                        @}
                                        @}
                                    </select>
                                </div>
                            </div>
                            <div class="layui-inline">
                                <button id="btnSearch" class="layui-btn icon-btn"><i class="layui-icon">&#xe615;</i>搜索</button>
                                <button id="btnExp" class="layui-btn icon-btn"><i class="layui-icon">&#xe67d;</i>导出</button>
                                <button id="orderStatistics" class="layui-btn icon-btn"><i class="layui-icon">&#xe62c;</i>运单统计</button>
                                <button id="deploy" class="layui-btn icon-btn"><i class="layui-icon">&#xe631;</i>配载</button>
                                <button id="feidan" class="layui-btn icon-btn"><i class="layui-icon">&#xe631;</i>废单</button>
                            </div>
                        </div>
                        <div class="layui-form-item layui-col-sm12 layui-col-md12 layui-col-lg12">
                            <div class="layui-tab layui-tab-brief" lay-filter="tradeorder">
                                <input type="hidden" id="transitStatus">
                                <ul class="layui-tab-title">
                                    <li class="layui-this" lay-id="0">全部</li>
                                    <li  lay-id="1">待配载</li>
                                    <li  lay-id="2">已配载</li>
                                    <li  lay-id="3">已发车</li>
                                    <li  lay-id="4">已到货</li>
                                </ul>
                            </div>
                        </div>
                    </div>

                    <table class="layui-table" id="jbrTradeorderTable" lay-filter="jbrTradeorderTable"></table>
                    <input type="hidden" id="data">
                    <table class="layui-table" id="jbrTradeorderTable1" lay-filter="jbrTradeorderTable1"></table>
                </div>
            </div>
        </div>
    </div>
</div>

<script type="text/html" id="tableBar">
    {{#  if(d.transitStatus ==1 || d.transitStatus ==2){ }}
    <a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="edit">修改</a>
    {{#  if(d.delStatus ==0){ }}
    {{#  if(d.transitStatus ==1){ }}
    @if(shiro.hasRole("administrator")){
    <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="delete">废单</a>
    @}
    {{#  } }}
    {{#  } }}
    {{#  } }}
</script>
@}

2.js文件

layui.use(['table', 'laydate','laytpl','admin', 'ax', 'func',"element"], function () {
    var $ = layui.$;
    var table = layui.table;
    var $ax = layui.ax;
    var admin = layui.admin;
    var func = layui.func;
    var element =layui.element;
    var laydate = layui.laydate;
    var laytpl = layui.laytpl;

    laydate.render({
        elem: '#queryCreatTime'
        ,type: 'date'
        ,range: '~'
    });
    /**
     * 运单表管理
     */
    var JbrTradeorder = {
        tableId: "jbrTradeorderTable"
    };
    element.on('tab(tradeorder)', function(data){
        var tradeorder= this.getAttribute('lay-id');
        $("#transitStatus").val(tradeorder);
        var queryData = {};
        if(tradeorder!=0){
            queryData['transitStatus'] = tradeorder;
        }else{
            queryData['transitStatus'] = null;
        }
        if(tradeorder==1 || tradeorder==0){
            $('#deploy').show();
            $('#feidan').show();
        }else{
            $('#deploy').hide();
            $('#feidan').hide();
        }
        table.reload(JbrTradeorder.tableId, {
            where: queryData, page: {curr: 1}
        });
    });
    /**
     * 初始化表格的列
     */
    JbrTradeorder.initColumn = function () {
        return [[
            {type: 'checkbox',field:'id'},
            {field: 'id', hide: true, title: ''},
            {align: 'center', toolbar: '#tableBar', title: '操作',width:150},
            {field: 'number', sort: true, title: '运单号',width:180},
            {field: 'ctmsNumber', sort: true, title: '3TMS受理单号',width:180},
            {field: 'transitStatusName', sort: true, title: '运输状态',width:120},
            {field: 'consignerName', sort: true, title: '寄件人姓名',width:180},
            {field: 'consignerPhone', sort: true, title: '寄件人电话',width:180},
            {field: 'consignerAddress', sort: true, title: '寄件人地址',width:180},
            {field: 'consigneeName', sort: true, title: '收件人姓名',width:180},
            {field: 'consigneePhone', sort: true, title: '收件人电话',width:180},
            {field: 'consigneeAddress', sort: true, title: '收件人地址',width:180},
            {field: 'cargoName', sort: true, title: '货物名称',width:180},
            {field: 'userName', sort: true, title: '开单员',width:180},
            {field: 'createTime', sort: true, title: '开单时间',width:180},
            {field: 'sourceStation', sort: true, title: '发站'},
            {field: 'targetStation', sort: true, title: '到站'},
            {field: 'quantity', sort: true, title: '件数'},
            {field: 'deliveryTypeName', sort: true, title: '送货方式',width:120},
            {field: 'paymentTypeName', sort: true, title: '支付方式',width:120},
            {field: 'freight', sort: true, title: '运费'},
            {field: 'statusName', sort: true, title: '运单状态',width:120},
            {field: 'tradetypeName', sort: true, title: '物流单种类',width:180},
            {field: 'payStatusName', sort: true, title: '支付状态',width:120}
        ]];
    };


    /**
     * 点击查询按钮
     */
    JbrTradeorder.search = function () {
        var tradeorder=  $("#transitStatus").val();
        var keywords=  $("#keywords").val();
        var queryCreatTime=$("#queryCreatTime").val();
        var queryRoad=  $("#queryRoad").val();
        var queryUser=  $("#queryUser").val();
        var queryData = {};
        if(queryCreatTime!=null && queryCreatTime!='' && queryCreatTime!='undefined' ){
            var dateArray=queryCreatTime.split('~');
            queryData['startDate'] = dateArray[0];
            queryData['endDate'] =  dateArray[1];
        }else{
            queryData['startDate'] = null;
            queryData['endDate'] =  null;
        }
        if(keywords!=null && keywords!='' && keywords!='undefined'){
            queryData['keywords'] = keywords;
        }else{
            queryData['keywords'] = null;
        }

        if(tradeorder!=0){
            queryData['transitStatus'] = tradeorder;
        }else{
            queryData['transitStatus'] = null;
        }
        if(queryRoad!=null && queryRoad!='' && queryRoad!='undefined'){
            queryData['rodeId'] = queryRoad;
        }else{
            queryData['rodeId'] = null;
        }
        if(queryUser!=null && queryUser!='' && queryUser!='undefined'){
            queryData['userId'] = queryUser;
        }else{
            queryData['userId'] = null;
        }
        console.log(queryData);
        table.reload(JbrTradeorder.tableId, {
            where: queryData, page: {curr: 1}
        });
    };

    /**
     * 弹出添加对话框
     */
    JbrTradeorder.openAddDlg = function () {
        func.open({
            title: '添加运单表',
            content: Feng.ctxPath + '/jbrTradeorder/add',
            tableId: JbrTradeorder.tableId
        });
    };

    /**
    * 点击编辑
    *
    * @param data 点击按钮时候的行数据
    */
    JbrTradeorder.openEditDlg = function (data) {
        func.open({
            title: '修改运单表',
            content: Feng.ctxPath + '/jbrTradeorder/edit?id=' + data.id,
            tableId: JbrTradeorder.tableId
        });
    };

    /**
     * 导出excel按钮
     */
    JbrTradeorder.exportExcel = function () {
        var checkRows = table.checkStatus(JbrTradeorder.tableId);
        if (checkRows.data.length === 0) {
            Feng.error("请选择要导出的数据");
        } else {
            table.exportFile(tableResult.config.id, checkRows.data, 'xls');
        }
    };

    /**
     * 处理废单
     *
     * @param data 点击按钮时候的行数据
     */
    JbrTradeorder.onDeleteItem = function (data) {
        var operation = function () {
           // var ajax = new $ax(Feng.ctxPath + "/jbrTradeorder/delete", function (data) {
            var ajax = new $ax(Feng.ctxPath + "/jbrTradeorder/delStatus", function (data) {
                Feng.success("处理成功!");
                table.reload(JbrTradeorder.tableId);
            }, function (data) {
                Feng.error("处理失败!" + data.responseJSON.message + "!");
            });
            ajax.set("id", data.id);
            ajax.start();
        };
        Feng.confirm("是否处理?", operation);
    };

    // 渲染表格
    var tableResult = table.render({
        elem: '#' + JbrTradeorder.tableId,
        url: Feng.ctxPath + '/jbrTradeorder/list',
        page: true,
        height: "full-98",
        cellMinWidth: 100,
        cols: JbrTradeorder.initColumn()
    });

    // 搜索按钮点击事件
    $('#btnSearch').click(function () {
        JbrTradeorder.search();
    });

    // 添加按钮点击事件
    $('#btnAdd').click(function () {
        JbrTradeorder.openAddDlg();
    });

    // 导出excel
    $('#btnExp').click(function () {
        JbrTradeorder.exportExcel();
    });

    //配载按钮
    $('#deploy').click(function () {
        var flag=true;
        var data=table.checkStatus('jbrTradeorderTable').data;
        $.each(data, function(i, val) {
            if(val.transitStatus!=1){
                flag=false;
                Feng.error("被选中的数据运输状态必须都为待配载");
            }
        });
        if(flag && data.length>0){
            var index =func.open({
                    title: '配载运单',
                    content: Feng.ctxPath + '/jbrTradeorder/deploy',
                    offset: 'lt',
                    type: 2,
                    tableId: JbrTradeorder.tableId,
                    shade: false,
                    zIndex: layer.zIndex, //重点1
                    success: function (layero, index) {
                        var body = layer.getChildFrame('body', index);
                        var w = $(layero).find("iframe")[0].contentWindow;
                        //body.find("#pdata").val(data);
                        w.child(data);
                    }
                });
           // layer.full(index);
        }else if(data.length==0){
            Feng.error("请选择需要配载的数据");
        }
    });

    // 点击运单统计按钮
    $('#orderStatistics').click(function () {
        var index = layer.open({
            type: 2,
            title: '运单统计',
            offset: 'lt',
            shade: false,
            tableId: JbrTradeorder.tableId,
            area: ["1100px", "580px"],
            content: '/jbrTradeorder/toOrderStatisticsPage',
            zIndex: layer.zIndex, //重点1
        });
        layer.full(index);
    });



    // 点击废单列表
    $('#feidan').click(function () {
      /*  var queryData = {};
            queryData['delStatus'] = 1;
        table.reload(JbrTradeorder.tableId, {
            where: queryData, page: {curr: 1}
        });*/
        var index = layer.open({
            type: 2,
            title: '废单列表',
            offset: 'lt',
            shade: false,
            tableId: JbrTradeorder.tableId,
            area: ["1100px", "580px"],
            content: '/jbrTradeorder/toOrderStatisticsPage',
            zIndex: layer.zIndex, //重点1
        });
        layer.full(index);
    });






    // 工具条点击事件
    table.on('tool(' + JbrTradeorder.tableId + ')', function (obj) {
        var data = obj.data;
        var layEvent = obj.event;

        if (layEvent === 'edit') {
            JbrTradeorder.openEditDlg(data);
        } else if (layEvent === 'delete') {
            JbrTradeorder.onDeleteItem(data);
        }
    });
});

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个基于jQuery和Masonry库实现的前端tab切换瀑布流代码示例: HTML代码: ``` <div class="tab-wrapper"> <ul class="tab-nav"> <li class="active"><a href="#tab1">Tab 1</a></li> <li><a href="#tab2">Tab 2</a></li> <li><a href="#tab3">Tab 3</a></li> </ul> <div class="tab-content"> <div id="tab1" class="tab-pane active"> <div class="grid"> <div class="grid-item"><img src="image1.jpg"></div> <div class="grid-item"><img src="image2.jpg"></div> <div class="grid-item"><img src="image3.jpg"></div> <div class="grid-item"><img src="image4.jpg"></div> <div class="grid-item"><img src="image5.jpg"></div> </div> </div> <div id="tab2" class="tab-pane"> <div class="grid"> <div class="grid-item"><img src="image6.jpg"></div> <div class="grid-item"><img src="image7.jpg"></div> <div class="grid-item"><img src="image8.jpg"></div> <div class="grid-item"><img src="image9.jpg"></div> <div class="grid-item"><img src="image10.jpg"></div> </div> </div> <div id="tab3" class="tab-pane"> <div class="grid"> <div class="grid-item"><img src="image11.jpg"></div> <div class="grid-item"><img src="image12.jpg"></div> <div class="grid-item"><img src="image13.jpg"></div> <div class="grid-item"><img src="image14.jpg"></div> <div class="grid-item"><img src="image15.jpg"></div> </div> </div> </div> </div> ``` CSS代码: ``` .tab-wrapper { width: 100%; margin: 0 auto; } .tab-nav { list-style: none; margin: 0; padding: 0; display: flex; justify-content: center; align-items: center; border-bottom: 1px solid #ccc; } .tab-nav li { margin: 0 10px; } .tab-nav li a { display: block; padding: 10px; color: #333; text-decoration: none; } .tab-nav li.active a { color: #f00; border-bottom: 2px solid #f00; } .tab-content { padding: 20px; } .grid { margin: 0; padding: 0; } .grid-item { margin: 10px; float: left; } .grid-item img { max-width: 100%; } ``` JavaScript代码: ``` $(document).ready(function() { // 初始化瀑布流布局 var $grid = $('.grid').masonry({ itemSelector: '.grid-item', columnWidth: '.grid-sizer', percentPosition: true }); // 切换tab时重新布局 $('.tab-nav a').on('click', function(e) { e.preventDefault(); var $tab = $(this).attr('href'); $('.tab-nav li').removeClass('active'); $(this).parent().addClass('active'); $('.tab-pane').removeClass('active'); $($tab).addClass('active'); $grid.masonry('layout'); }); }); ``` 通过以上代码,我们实现了一个基于jQuery和Masonry库的前端tab切换瀑布流效果。当用户点击不同的tab标签时,页面中的瀑布流布局会重新布局,以适应当前tab内容的大小和数量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值