为什么拆分按钮下拉隐藏了单元格后面的选项?

时间:2017-05-03 14:55:34

标签: jquery css twitter-bootstrap jqgrid

我添加了一个列,在jqGrid网格中有引导分割按钮下拉列表。这是一个反应组件和代码如下:

反应代码:

    "use strict";

var EmployeeGrid = React.createClass({
    displayName: "EmployeeGrid",

    componentDidMount: function componentDidMount() {
        this.loadGrid();
    },
    loadGrid: function loadGrid() {
        var $grid = $("#list"),
            resizeGrid = function resizeGrid() {
            var newWidth = $grid.closest(".ui-jqgrid").parent().width();
            $grid.jqGrid("setGridWidth", newWidth, true);
        };
        $(window).on("resize", function () {
            resizeGrid();
        });

        var $body = $('body');

        $.ajax({
            url: 'sample.json',
            dataType: 'json',
            success: function success(data1) {
                var d1 = data1;
                console.log('hello');
                $("#list").jqGrid({
                    data: d1,
                    colNames: ["id", "FirstName", "LastName", "Country", "Status"],
                    colModel: [{ name: "id", align: "center", hidden: true },
                        { name: "FirstName", align: "center", sortable: false, hidden: false },
                        { name: "LastName", align: "center", sortable: false, hidden: false },
                        { name: "Country", align: "center", sortable: false, hidden: false },
                        { name: "Status",
                        align: "center",
                        width: 93,
                        sortable: false,
                        edittype: 'select',
                        hidden: false,
                        editoptions: { value: { '1': 'Hired', '2': 'Extended', '3': 'Terminated',
                                '4': 'Fired', '5': 'Retired' }, defaultValue: 'Hired' },
                        formatoptions: { disabled: false },
                        formatter: function formatter(cellvalue, options, rowObject) {

                            var str = '<div class="btn-group"> ' + '<button type="button" class="btn btn-sm btn-success" style="min-width: 65px;max-width: 65px">Action</button>' + '<button type="button" class="btn btn-sm btn-success dropdown-toggle" data-toggle="dropdown">' + '<span class="caret"></span>' + '<span class="sr-only">Toggle Dropdown</span>' + '</button>' + '<ul class="dropdown-menu" role="menu">' + '<li><a href="#">Hired</a></li>' + '<li><a href="#">Extended</a></li>' + '<li><a href="#">Terminated</a></li>' + '<li><a href="#">Retired</a></li>' + '</ul>' + '</div>';

                            return str;
                        } }],
                    loadComplete: function() {//chaneg the height of each row to 200
                        var grid = $("#list");
                        var ids = jQuery("#list").jqGrid('getDataIDs');
                        for (var i = 0; i < ids.length; i++) {
                            grid.jqGrid('setRowData',ids[i], false, { height : 200 });
                        }
                    },
                    cmTemplate: { autoResizable: true },
                    autoResizing: { compact: true, resetWidthOrg: true },
                    autowidth: true,
                    height: 350,
                    iconSet: "fontAwesome",
                    guiStyle: "bootstrap",
                    pager: '#pager',
                    caption: 'Employees Listing',
                    pgbuttons: false,
                    viewrecords: false,
                    pgtext: "",
                    pginput: false

                });
            },
            error: function error(x,y,z) {
                //alert('DATA CANNOT READ'+ JSON.stringify(x));
                console.log(JSON.stringify(x));
            }
        });
    },
    render: function render() {
        return React.createElement(
            "div",
            null,
            React.createElement(
                "div",
                null,
                React.createElement(
                    "h1",
                    null,
                    "Top header"
                )
            ),
            React.createElement(
                "div",
                null,
                React.createElement(
                    "div",
                    { className: "container-fluid" },
                    React.createElement("table", { id: "list" }),
                    React.createElement("div", { id: "pager" })
                )
            ),
            React.createElement(
                "div",
                null,
                React.createElement(
                    "h1",
                    null,
                    "bottom header"
                )
            )
        );
    }
});


/////////////////////////////////////////////////////////
// this code will show the seleted text on the button
////////////////////////////////////////////////////////////
$('.btn-success').on('click',function(e){
    e.preventDefault();
})
$('.dropdown-menu a').on('click', function(e){
    e.preventDefault();
    var anchor = $(e.currentTarget);
    var href = anchor.attr('href');
    var text = anchor.text();
    var button = anchor.closest('.btn-group').find('button:first-child');
    button.attr('data-url', href);
    button.text(text);
    button.on('click', gotoUrl);
});
function gotoUrl(e){
    e.preventDefault();

}
/////////////////////////////////////////////////////


ReactDOM.render(React.createElement(EmployeeGrid, null), document.getElementById('divOuterContainer'));

HTML:

**

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/themes/south-street/jquery-ui.min.css" />
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.css">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.css">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/free-jqgrid/4.14.0/css/ui.jqgrid.min.css">
    <style>
        .ui-jqgrid tr.jqgrow > td {
            white-space: normal;
        }
        /****************************************/
        .ui-jqgrid.ui-jqgrid-bootstrap .ui-jqgrid-caption,
        .ui-jqdialog.ui-jqgrid-bootstrap .ui-jqdialog-titlebar {
            background-color: #009926;
            color: white;
        }
        .ui-jqgrid.ui-jqgrid-bootstrap .ui-jqgrid-hdiv {
            background-color: #009926;
            color:#fff;
            font-weight: bold;
        }
        .ui-jqgrid-bootstrap.ui-jqgrid .ui-jqgrid-toppager,
        .ui-jqgrid-bootstrap.ui-jqgrid .ui-jqgrid-pager {
            background-color: #009926;
            color:#fff;
        }
        .table > thead > tr > td.active,
        .table > tbody > tr > td.active,
        .table > thead > tr > th.active,
        .ui-pg-table .ui-pg-button.active,
        .ui-jqgrid-actions .ui-pg-div.active {
            background-color: #009926;
        }
        /*fixes split buttons breaking when page resizes*/
        .btn-group {
            white-space: nowrap;
            font-size: 0;
        }
        .btn-group-vertical>.btn, .btn-group>.btn {
            display:inline-block;
            float:none;
        }
    </style>
</head>
<body>
<div id="divOuterContainer" class="container-fluid"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.34/browser.min.js"></script>
<script>
    $.jgrid = $.jgrid || {};
    $.jgrid.no_legacy_api = true;
    $.jgrid.useJSON = true;
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.14.0/jquery.jqgrid.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.js"></script>
<script type="text/javascript" src="EmployeeGrid.js">
</script>
</body>
</html>

**

在上面的代码堆栈溢出不会让我添加facebook的反应库。所以请在测试代码时添加反应文件,即: react-15.0.0.js react-dom-15.0.0.js

它使用的JSON数据

[{"id":1, "FirstName":"John","LastName":"Akram", "Country":"USA", "Status":"Hired"},
  {"id":2, "FirstName":"John","LastName":"Akram", "Country":"USA", "Status":"Hired"},
  {"id":3, "FirstName":"John","LastName":"Akram", "Country":"USA", "Status":"Hired"}
]

它生成以下网格:

enter image description here

问题#1: 正如你在代码中看到的,我为分裂按钮添加了四个选项

  1. 雇工
  2. 扩展
  3. 终止
  4. 退休
  5. 但是你可以在图片中看到它只显示三个选项,为什么它隐藏了单元格内的最后一个选项“Retired”,我该如何解决这个问题?

    问题#2:

    enter image description here

    如您所见,用户选择了选项,但所选选项不会显示在按钮上。但是我已经为它编写了代码,如果你看到网格代码底部的反应代码

    $('.btn-success').on('click',function(e){
        e.preventDefault();
    })
    $('.dropdown-menu a').on('click', function(e){
        e.preventDefault();
        var anchor = $(e.currentTarget);
        var href = anchor.attr('href');
        var text = anchor.text();
        var button = anchor.closest('.btn-group').find('button:first-child');
        button.attr('data-url', href);
        button.text(text);
        button.on('click', gotoUrl);
    });
    function gotoUrl(e){
        e.preventDefault();
    
    }
    

    但是为什么它不会将选定的选项文本设置为按钮的文本?我该如何解决这个问题?

1 个答案:

答案 0 :(得分:2)

这应该解决它:

tr.jqgrow:hover {
  position:relative;
  z-index: 1;
}

如果在:hover上正确显示它是不够的,请考虑在下拉列表中向该行添加一个类并在关闭时将其删除:

$(this).closest('tr.jqgrow').addClass('opened');

...需要进入下拉列表的公开事件。并且需要在下拉关闭事件中删除。当然,将上面的CSS调整为tr.jqgrow.opened {...}

要检查的另一件事是.dropdown个父母是否有overflow:hidden,并用visible覆盖它。