Хобрук: Ваш путь к мастерству в программировании

Добавление отступов к элементам в макете «fit» добавляет пустое пространство сверху

Я хочу создать табличную структуру в ExtJs с метками и флажками. Обычно я бы использовал панель с макетом «vbox», чтобы сложить ряд панелей с макетом «hbox». Таким образом, я получаю структуру вроде:

vbox
|
\|/ 
John Doe [] [] [] [] <- hbox
Jane Doe [] [] [] [] <- hbox

Записи загружаются динамически из источника данных. Это означает, что я не могу использовать макет таблицы, который в любом случае устарел.

Однако «vbox» недостаточно хорошо справляется с переполнением. Он просто обрезает его, хотя мне нужны полосы прокрутки. Поэтому я выбрал макет «по размеру», который в настоящее время расширяет панель «по размеру», чтобы вместить все записи. Это подойдет так же, как и полосы прокрутки, которые я, вероятно, все равно получил бы, если бы указал высоту.

Я хочу заполнить элементы вокруг элементов, и когда я добавляю это, все идет не так. Первая запись сильно увеличивается в размерах.

Размер приходит на страницу из следующего элемента:

div class="x-panel-body x-panel-body-noheader x-box-layout-ct" id="ext-gen82" style="width: 1621px; height: 2680px;"

У меня есть отступ 10 пикселей и 135 записей, поэтому кажется, что высота в 134 раза больше отступа в обоих направлениях.

Я попытался сохранить панель «vbox» и обернуть ее внутри панели «fit», но это все равно создавало пустое пространство и разрушало макет.

У меня есть аналогичная проблема в другом месте приложения, и я работаю над ней уже много дней. Буду очень признателен за любую помощь!

Код, указанный ниже

        var pnlRelations = new Ext.Panel({
            autoScroll: true,
            frame: true,
            id: 'pnlRelations',
            title: 'Servers',
            renderTo: 'pnlServers',
            layout: 'fit',                
            items: [

            ],
            buttons: [
                { text: 'Opslaan', handler: submit }
            ]
        });

        var storeServerMaintenance = new Ext.data.Store({
            id: 'storeServerMaintenance',
            autoLoad: true,
            proxy: new Ext.data.HttpProxy({ url: '<%= Url.Action("ListMaintenanceServer", "Maintenance") %>' }),
            reader: new Ext.data.JsonReader({
                    //                totalProperty: 'records',
                    idProperty: 'Id',
                    root: 'rows'
                },
                <%= ServerMaintenanceListItem.ToColumnModel() %>

            ),
            /*remoteSort: true*/
            listeners: {
                load: function (store, records, ops) {
                    nrOfRecords = records.length;
                    for (var i = 0; i < records.length; i++) {
                        var rec = records[i];
                        var serverId = rec.get('Id') == null ? null : rec.get('Id');
                        var relationId = rec.get('RelationId') == null ? null : rec.get('RelationId');
                        var q1 = rec.get('Q1') != null && rec.get('Q1');
                        var q2 = rec.get('Q2') != null && rec.get('Q2');
                        var q3 = rec.get('Q3') != null && rec.get('Q3');
                        var q4 = rec.get('Q4') != null && rec.get('Q4');
                        pnlRelations.add(new Ext.Panel({
                            layout: 'hbox',
                            //                                defaults: { margins: 10 },
                            style:{padding:'10px'},
                            items: [
                                new Ext.form.Label({ html: rec.get('RelationName'), width: labelWidth }),
                                new Ext.form.Label({ html: rec.get('Name'), width: labelWidth }),
                                new Ext.form.Label({ id: 'idx_' + i, html: '' + rec.get('Index'), width: boxWidth }),
                                new Ext.form.Checkbox({ id: 'cbQ1_' + i, width: boxWidth, checked: q1 }),
                                new Ext.form.Checkbox({ id: 'cbQ2_' + i, width: boxWidth, checked: q2 }),
                                new Ext.form.Checkbox({ id: 'cbQ3_' + i, width: boxWidth, checked: q3 }),
                                new Ext.form.Checkbox({ id: 'cbQ4_' + i, width: boxWidth, checked: q4 }),
                                new Ext.form.Hidden({ id: 'hfServer_' + i, value: serverId }),
                                new Ext.form.Hidden({ id: 'hfRelation_' + i, value: relationId })
                            ]
                        }));
                    }
                    //                        debugger;
                    pnlRelations.doLayout();
                }
            }
        });
29.07.2015

  • Было бы здорово, если бы вы могли предоставить какой-либо код для этого? 29.07.2015
  • Кстати. вы пробовали со свойством: columns ? Например: layout: hbox, columns: 5 29.07.2015
  • @PawełGłowacz Я добавил код. Я не видел упоминания о колонках в документации макета hbox. Я только что попробовал, и он работает точно так же: все еще огромный разрыв ниже первой записи. 29.07.2015

Ответы:


1

пытаться

layout: {
    type: 'hbox',
    align: 'stretch'
}

И добавить

flex: 1

в каждый из ваших "элементов"

29.07.2015
  • Это не сработало, элементы не были показаны. Я добавил высоту на «внешнюю» панель, после чего появился первый элемент. Его элементы имели высоту 932 пикселя, моя внешняя оболочка была 1000. Я полагаю, вы имели в виду, что для моих панелей hbox требуется «растягивание», а для всех элементов внутри них — flex 1? 30.07.2015

  • 2

    Мне удалось это исправить! По иронии судьбы, это произошло, когда я максимально вернул страницу к основам. Я удалил макет: «подходит» и вообще не имел макета. Затем я добавил отступы к панелям hbox.

    var pnlRelations = new Ext.Panel({
                autoScroll: true,
                frame: true,
                id: 'pnlRelations',
                title: 'Servers',
                renderTo: 'pnlServers',
    //                layout: 'fit',                
                items: [
    
                ],
                buttons: [
                    { text: 'Opslaan', handler: submit }
                ]
            });
    
    var storeServerMaintenance = new Ext.data.Store({
                id: 'storeServerMaintenance',
                autoLoad: true,
                proxy: new Ext.data.HttpProxy({ url: '<%=     Url.Action("ListMaintenanceServer", "Relatie") %>' }),
                reader: new Ext.data.JsonReader({
                    //                totalProperty: 'records',
                    idProperty: 'Id',
                    root: 'rows'
                },
                    <%= ServerMaintenanceListItem.ToColumnModel() %>
    
                ),
                /*remoteSort: true*/
                listeners: {
                    load: function (store, records, ops) {
                        nrOfRecords = records.length;
                        for (var i = 0; i < records.length; i++) {
                            var rec = records[i];
                            var serverMaintenanceId = rec.get('Id') == null ? null : rec.get('Id');
                            var relationServerId = rec.get('RelationServerId');
                            var relationId = rec.get('RelationId') == null ? null : rec.get('RelationId');
                            var q1 = rec.get('Q1') != null && rec.get('Q1');
                            var q2 = rec.get('Q2') != null && rec.get('Q2');
                            var q3 = rec.get('Q3') != null && rec.get('Q3');
                            var q4 = rec.get('Q4') != null && rec.get('Q4');
                            pnlRelations.add(new Ext.Panel({
                                layout: { type: 'hbox' },
                                padding: 4,
                                items: [
                                    new Ext.form.Label({ html: rec.get('RelationName'), width: labelWidth }),
                                    new Ext.form.Label({ html: rec.get('Name'), width: labelWidth }),
                                    new Ext.form.Label({ html: '' + rec.get('Index'), width: boxWidth }),
                                    new Ext.form.Checkbox({ id: 'cbQ1_' + i, width: boxWidth, checked: q1 }),
                                    new Ext.form.Checkbox({ id: 'cbQ2_' + i, width: boxWidth, checked: q2 }),
                                    new Ext.form.Checkbox({ id: 'cbQ3_' + i, width: boxWidth, checked: q3 }),
                                    new Ext.form.Checkbox({ id: 'cbQ4_' + i, width: boxWidth, checked: q4 }),
                                    new Ext.form.Hidden({ id: 'idx_' + i, value: rec.get('Index') }),
                                    new Ext.form.Hidden({ id: 'hfRelationServer_' + i, value: relationServerId }),
                                    new Ext.form.Hidden({ id: 'hfServerMaintenanceId_' + i, value: serverMaintenanceId }),
                                    new Ext.form.Hidden({ id: 'hfRelation_' + i, value: relationId })
                                ]
                            }));
                        }
                        //                        debugger;
                        pnlRelations.doLayout();
                    }
                }
    
    31.07.2015
    Новые материалы

    Освоение информационного поиска: создание интеллектуальных поисковых систем (глава 1)
    Глава 1. Поиск по ключевым словам: основы информационного поиска Справочная глава: «Оценка моделей поиска информации: подробное руководство по показателям производительности » Глава 1: «Поиск..

    Фишинг — Упаковано и зашифровано
    Будучи старшим ИТ-специалистом в небольшой фирме, я могу делать много разных вещей. Одна из этих вещей: специалист по кибербезопасности. Мне нравится это делать, потому что в настоящее время я..

    ВЫ РЕГРЕСС ЭТО?
    Чтобы понять, когда использовать регрессионный анализ, мы должны сначала понять, что именно он делает. Вот простой ответ, который появляется, когда вы используете Google: Регрессионный..

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..