Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
cst-angular-vs-repeat
Advanced tools
Check out https://github.com/kamilkp/ng2-vs-for
top
updating directives - even better performanceVirtual Scroll for AngularJS ngRepeat directive
Demo: http://kamilkp.github.io/angular-vs-repeat/
You can find the source code for this demo on branch "gh-pages".
Changelog: https://github.com/kamilkp/angular-vs-repeat/blob/master/CHANGELOG.md
###DESCRIPTION:
vsRepeat
directive stands for Virtual Scroll Repeat. It turns a standard ngRepeated set of elements in a scrollable container
into a component, where the user thinks he has all the elements rendered and all he needs to do is scroll (without any kind of
pagination - which most users loath) and at the same time the browser isn't overloaded by that many elements/angular bindings etc.
The directive renders only so many elements that can fit into current container's clientHeight
/clientWidth
.
###LIMITATIONS:
ngRepeat
###USAGE:
First include vs-repeat
as a module dependency in your app.
In order to use the vsRepeat directive you need to place a vs-repeat attribute on a direct parent of an element with ng-repeat
example:
<div vs-repeat>
<div ng-repeat="item in someArray">
<!-- content -->
</div>
</div>
or:
<div vs-repeat>
<div ng-repeat-start="item in someArray">
<!-- content -->
</div>
<div>
<!-- something in the middle -->
</div>
<div ng-repeat-end>
<!-- content -->
</div>
</div>
You can also measure the single element's height/width (including all paddings and margins), and then speficy it as a value of the attribute 'vs-repeat'. This can be used if one wants to override the automatically computed element size. example:
<div vs-repeat="50"> <!-- the specified element height is 50px -->
<div ng-repeat="item in someArray">
<!-- content -->
</div>
</div>
ngRepeat
###OPTIONAL PARAMETERS (attributes):
vs-scroll-parent="selector"
- selector to the scrollable container. The directive will look for a closest parent matching the given selector (defaults to the current element). It can also have the value of "window" in which case the directive will hook on the main window scrollbarvs-offset-before="value"
- top/left offset in pixels (defaults to 0)vs-offset-after="value"
- bottom/right offset in pixels (defaults to 0)vs-horizontal
- horizontal mode (the ngRepeat'ed elements should be horizontally stacked)vs-excess="value"
- an integer number representing the number of elements to be rendered outside of the current container's viewport (defaults to 2)vs-size="expression"
- an angular expression evaluated on the item scope that should return the item size. Can be a function or a property name or whatevervs-autoresize
- use this attribute without vs-size
and without specifying element's size. The automatically computed element style will readjust upon window resize if the size is dependable on the viewport sizevs-options="{latch: true}"
enables latching mode - elements once rendered are not being removed when scrolled away (improves scrolling performance when the rendering of each element is time consuming)vs-scrolled-to-end="callback"
callback will be called when the last item of the list is renderedvs-scrolled-to-end-offset="integer"
- set this number to trigger the scrolledToEnd callback n items before the last gets rendered###EVENTS:
vsRepeatTrigger
- an event the directive listens for to manually trigger reinitializationvsRepeatResize
- an event the directive listens for to manually trigger the autosizing algorithmvsRepeatReinitialized
- an event the directive emits upon reinitialization done; the listener may accepts three arguments: event
, startIndex
and endIndex
FAQs
Virtual Scroll for AngularJS ngRepeat directive
We found that cst-angular-vs-repeat demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.