1

チェックボックスをグリッド列として有効にしてjqxDropDownListを利用するための適切な実装方法を誰かが提供できますか?

次のコードは、jqwidgets グリッド デモ コード「cellediting.htm」から変更されています。

チェックボックス付きの独立したドロップダウンリストを問題なく実装しました。

問題なくドロップダウンリスト(チェックボックスなし)でグリッドを実装しました。

ただし、チェックボックスを配置するとすぐに、イニシエータに true があり、次のエラーが発生します。

キャッチされていない TypeError: 未定義の jqxlistbox.js:7 のプロパティ 'インスタンス' を読み取ることができません

特定の「より複雑な」シナリオでは、checkboxes プロパティは「createeditor」では成功しますが、initeditor では失敗します。これにより、非同期の読み込みが行われている可能性があり、エディターの構築が速すぎると思われます。

次のコードは、'checkboxes: true' プロパティが原因で失敗します。それを削除すると、うまく機能します。

<head>
    <title id='Description'>In order to enter in edit mode, select a grid cell and start typing, "Click" or press the "F2" key. You 
    can also navigate through the cells using the keyboard arrows or with the "Tab" and "Shift + Tab" key combinations. To cancel the cell editing, press the "Esc" key. To save
    the changes press the "Enter" key or select another Grid cell. Pressing the 'Space' key when a checkbox cell is selected will toggle the check state.</title>
    <link rel="stylesheet" href="../../jqwidgets/styles/jqx.base.css" type="text/css" />
    <script type="text/javascript" src="../../scripts/jquery-1.8.3.min.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxcore.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxdata.js"></script> 
    <script type="text/javascript" src="../../jqwidgets/jqxbuttons.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxscrollbar.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxmenu.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.edit.js"></script>  
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.selection.js"></script> 
    <script type="text/javascript" src="../../jqwidgets/jqxgrid.filter.js"></script> 
    <script type="text/javascript" src="../../jqwidgets/jqxlistbox.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxdropdownlist.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxcheckbox.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxcalendar.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxnumberinput.js"></script>
    <script type="text/javascript" src="../../jqwidgets/jqxdatetimeinput.js"></script>
    <script type="text/javascript" src="../../jqwidgets/globalization/globalize.js"></script>
    <script type="text/javascript" src="../../scripts/gettheme.js"></script>
    <script type="text/javascript" src="generatedata.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            // prepare the data
            var data = 
            [
                { firstname: 'joe', lastname: 'smith', sex: 'm' },
                { firstname: 'john', lastname: 'doe', sex: 'm' },
                { firstname: 'jane', lastname: 'doe', sex: 'f' }
            ];
            var source =
            {
                localdata: data,
                datatype: "array",
                updaterow: function (rowid, rowdata, commit) {
                    commit(true);
                },
                datafields:
                [
                    { name: 'firstname', type: 'string' },
                    { name: 'lastname', type: 'string' },
                    { name: 'sex', type: 'string' }
                ]
            };
            var dataAdapter = new $.jqx.dataAdapter(source);
            // initialize jqxGrid
            $("#jqxgrid").jqxGrid(
            {
                width: 685,
                source: dataAdapter,
                editable: true,
                selectionmode: 'multiplecellsadvanced',
                columns: [
                  { text: 'First Name', columntype: 'textbox', datafield: 'firstname', width: 80 },
                  { text: 'Last Name', columntype: 'textbox', datafield: 'lastname', width: 80 },
                  {  text: 'Sex', columntype: 'dropdownlist', datafield: 'sex', width: 195,
                    createeditor: function(row, cellvalue, editor)
                    {
                        var mydata =
                        [
                            { value: "m", label: "Male" },
                            { value: "f", label: "Female" }
                        ];
                        var mysource =
                        {
                            datatype: "array",
                            datafields:
                            [
                                { name: 'label', type: 'string' },
                                { name: 'value', type: 'string' }
                            ],
                            localdata: mydata
                        };
                        var myadapter = new $.jqx.dataAdapter(mysource, { autoBind: true });
                        editor.jqxDropDownList({ checkboxes: true, source: myadapter, displayMember: 'label', valueMember: 'value' });
                    }
                  }
                ]
            });
            // events
            $("#jqxgrid").on('cellbeginedit', function (event) {
                var args = event.args;
                $("#cellbegineditevent").text("Event Type: cellbeginedit, Column: " + args.datafield + ", Row: " + (1 + args.rowindex) + ", Value: " + args.value);
            });
            $("#jqxgrid").on('cellendedit', function (event) {
                var args = event.args;
                $("#cellendeditevent").text("Event Type: cellendedit, Column: " + args.datafield + ", Row: " + (1 + args.rowindex) + ", Value: " + args.value);
            });
        });
    </script>
</head>
<body class='default'>
    <div id='jqxWidget'>
        <div id="jqxgrid"></div>
        <div style="font-size: 12px; font-family: Verdana, Geneva, 'DejaVu Sans', sans-serif; margin-top: 30px;">
            <div id="cellbegineditevent"></div>
            <div style="margin-top: 10px;" id="cellendeditevent"></div>
       </div>
    </div>
</body>
</html>

誰でも支援を提供できますか?

追加ヘルプ!! さらに、ドロップダウンで値を選択すると、実際の「値」が表示「ラベル」に変更されるようです。つまり、(「男性」または「女性」) ですが、この例では、性別フィールドの有効なデータは「m」または「f」のみです。

jqwidgets の公式フォーラム (ここ: http://www.jqwidgets.com/community/topic/dropdownlist-with-checkboxes-as-grid-column-editor/ ) で同じ質問をして、回答を投稿します。コミュニティを打ち負かした場合、彼らはここに送信します。

4

2 に答える 2

0

これはかなり古い投稿であることは知っていますが、それでも... JQWidgets チームからの応答を見て驚いています。彼ら自身の Web サイトに、チェックボックス付きのドロップダウンリストをグリッド エディターとして使用する例があるからです。これは、http://www.jqwidgets.com/jquery-widgets-demo/demos/jqxgrid/index.htm#demos/jqxgrid/cellcustomediting.htmで入手でき 、Products 列でエディターが使用されています。

ミハイ

于 2014-07-09T06:30:31.787 に答える