Скрыть дополнительные столбцы таблицы mat, если она превышает длину экрана, и отобразить, если я нажму кнопку +, которая будет расположена рядом с ним - PullRequest
0 голосов
/ 24 декабря 2018

Я использую дизайн материала в своем приложении, и количество столбцов, отображаемых в моей таблице mat, является динамическим.Поэтому, если длина моего столбца превышает размер экрана, я хочу скрыть дополнительные столбцы и отобразить их, когда нажимаю кнопку (+), которую я помещу рядом с таблицей.когда я нажимаю на эту кнопку, я хочу отобразить 2 скрытых столбца и скрыть 2 отображаемых столбца.Как я могу работать в Angular Material UI, может кто-нибудь, пожалуйста, помогите мне.

1 Ответ

0 голосов
/ 14 февраля 2019

пройти через это для ответа.Это ясно объясняет, как скрыть дополнительные столбцы и отобразить их

https://codepen.io/paghdalyogesh/pen/qNzGVx

<md-table-container>
    <table resize md-table md-row-select="options.rowSelection" multiple="{{options.multiSelect}}" ng-model="selected"
        md-progress="promise">
        <thead id="tablewidth" ng-if="!options.decapitate" md-head md-order="query.order" md-on-reorder="logOrder">
            <tr md-row>
                <th class="plusbuttonicon thaa0" data-title="Name" md-cell>#</th>
                <th class="Present thaa1" md-column md-order-by="name">
                    <span>Dessert (100g serving)</span>
                </th>
                <th class="Present thaa2" md-column md-order-by="type">
                    <span>Type</span>
                </th>
                <th class="Present thaa3" md-column md-numeric md-order-by="calories.value" md-desc><span>Calories</span></th>
                <th class="Present thaa4" md-column md-numeric md-order-by="fat.value">
                    <span>Fat (g)</span>
                </th>
                <th class="Present thaa5" md-column md-numeric md-order-by="carbs.value">
                    <span>Carbs (g)</span>
                </th>
                <th class="Present thaa6" md-column md-numeric md-order-by="protein.value">
                    <span>Protein (g)</span>
                </th>
                <th class="Present thaa7" md-column md-numeric md-order-by="sodium.value">
                    <span>Sodium (mg)</span>
                </th>
                <th class="Present thaa8" md-column md-numeric md-order-by="calcium.value">
                    <span>Calcium (%)</span>
                </th>
                <th class="Present thaa9" md-column md-numeric md-order-by="iron.value">
                    <span>Iron (%)</span>
                </th>
            </tr>
        </thead>
        <tbody md-body>
            <tr class="primary trid{{dessert.id}}" md-row md-select="dessert" md-on-select="logItem" md-auto-select="options.autoSelect"
                ng-disabled="dessert.calories.value > 400" ng-repeat-start="dessert in desserts.data | filter: filter.search | orderBy: query.order | limitTo: query.limit : (query.page -1) * query.limit">
                <td class="plusbuttonicon" md-cell>

                    <md-button id="{{dessert.id}}" ng-click="movedata();" class="md-icon-button downarrow-{{dessert.id}} downarrow">
                        <i id="downarrow" class="material-icons">&#xE313;</i>
                    </md-button>
                    <md-button id="{{dessert.id}}" ng-click="movedata();" class="md-icon-button uparrow-{{dessert.id}} uparrow">
                        <i id="uparrow" class="material-icons">&#xE316;</i>
                    </md-button>
                </td>
                <td class="thaa1" data-title="Name" md-cell>{{dessert.name}}</td>
                <td class="thaa2" data-title="Type" md-cell>
                    <md-select ng-model="dessert.type" placeholder="Other">
                        <md-option ng-value="type" ng-repeat="type in getTypes()">{{type}}</md-option>
                    </md-select>
                </td>
                <td class="thaa3" data-title="Calories" md-cell>{{dessert.calories.value}}</td>
                <td class="thaa4" data-title="Fat" md-cell>{{dessert.fat.value | number: 2}}</td>
                <td class="thaa5" data-title="Carbs" md-cell>{{dessert.carbs.value}}</td>
                <td class="thaa6" data-title="Protein" md-cell>{{dessert.protein.value | number: 2}}</td>
                <td class="thaa7" data-title="Sodium" md-cell>{{dessert.sodium.value}}</td>
                <td class="thaa8" data-title="Calcium" md-cell>{{dessert.calcium.value}}%</td>
                <td class="thaa9" data-title="Iron" md-cell>{{dessert.iron.value}}%</td>
            </tr>
            <tr class="secondary childid{{dessert.id}}" ng-repeat-end></tr>
        </tbody>
    </table>
</md-table-container>
<md-table-pagination md-limit="query.limit" md-limit-options="limitOptions" md-page="query.page" md-total="{{desserts.count}}"
    md-page-select="options.pageSelect" md-boundary-links="options.boundaryLinks" md-on-paginate="logPagination"></md-table-pagination>
...