Angular Material - 虚拟重复
md-virtual-repeat-container 是 md-virtual-repeat 组件的滚动容器。
属性
下表列出了md-virtual-repeat-container的参数和不同属性的说明。
Sr.No | 参数和描述 |
---|---|
1 | md-top-index 将滚动容器顶部的项目索引绑定到$scope。 它既可以读取也可以设置滚动位置。 |
2 | md-orient-horizontal 确定容器是否应水平滚动(默认为方向并垂直滚动)。 |
3 | md-auto-shrink 如果存在,当项目数量小于其原始大小时,容器将缩小以适应项目数量。 |
4 | md-auto-shrink-min md-auto-shrink 将缩小到的最小项目数(默认值:0)。 |
md-virtual-repeat
虚拟重复是 ng-repeat 的替代品,它只渲染足够的 html 元素来填充容器并在用户滚动时重用它们。
属性
下表列出了md-virtual-repeat不同属性的参数及说明。
Sr.No | 参数和描述 |
---|---|
1 | md-item-size 重复元素的高度或宽度(每个元素必须相同)。 这是可选的。 如果丢失,这会尝试从 dom 读取大小,但仍然假设所有重复节点具有相同的高度或宽度。 |
2 | md-extra-name 计算出一个附加名称,当前迭代项可以在重复范围内分配给该附加名称(需要在 md-autocomplete 中使用)。 |
3 | md-on-demand 如果存在,则将 md-virtual-repeat 参数视为可以获取行而不是数组的对象。该对象必须使用两 (2) 个方法实现以下接口 −
|
示例
以下示例展示了虚拟重复的使用。
am_virtualrepeat.html
<html lang = "en"> <head> <link rel = "stylesheet" href = "https://www.w3ccoo.com/lib/angular_material/1.0.0/angular-material.min.css"> <script src = "https://cdn.staticfile.org/angular.js/1.4.8/angular.min.js"></script> <script src = "https://cdn.staticfile.org/angular.js/1.4.8/angular-animate.min.js"></script> <script src = "https://cdn.staticfile.org/angular.js/1.4.8/angular-aria.min.js"></script> <script src = "https://cdn.staticfile.org/angular.js/1.4.8/angular-messages.min.js"></script> <script src = "https://www.w3ccoo.com/lib/angular_material/1.0.0/angular-material.min.js"></script> <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons"> <style> .vrepeatContainer #horizontal-container { height: 100px; width: 830px; } .vrepeatContainer #vertical-container { height: 292px; width: 400px; } .vrepeatContainer .repeated-item-horizontal { border-right: 1px solid #ddd; box-sizing: border-box; display: inline-block; height: 84px; padding-top: 35px; text-align: center; width: 50px; } .vrepeatContainer .repeated-item-vertical { border-bottom: 1px solid #ddd; box-sizing: border-box; height: 40px; padding-top: 10px; } .vrepeatContainer md-content { margin: 16px; } .vrepeatContainer md-virtual-repeat-container { border: solid 1px grey; } </style> <script language = "javascript"> angular .module('firstApplication', ['ngMaterial']) .controller('vrepeatController', vrepeatController); function vrepeatController ($scope) { this.items = []; for (var i = 0; i < 1000; i++) { this.items.push(i); } } </script> </head> <body ng-app = "firstApplication"> <div class = "vrepeatContainer" ng-controller = "vrepeatController as ctrl" ng-cloak> <md-content layout = "column"> <h2>Horizontal Repeat</h2> <md-virtual-repeat-container id = "horizontal-container" md-orient-horizontal> <div md-virtual-repeat = "item in ctrl.items" class = "repeated-item-horizontal" flex> {{item}} </div> </md-virtual-repeat-container> <h2>Vertical Repeat</h2> <md-virtual-repeat-container id = "vertical-container"> <div md-virtual-repeat = "item in ctrl.items" class = "repeated-item-vertical" flex> {{item}} </div> </md-virtual-repeat-container> </md-content> </div> </body> </html>
结果
验证结果。