mirror of
https://github.com/krateng/maloja.git
synced 2023-08-10 21:12:55 +03:00
Lazy load tile and entity background images
CSS 'background-image:url' causes the browser to synchronously load images which prevents DOM from fully loading. Replace this with lazyload.js to make * js load style=background-image... after DOM is loaded and * only load images in viewport The end result is much faster *apparent* page loads as all DOM is loaded before images and a reduction in load for both client/server as images are only loaded if they become visible.
This commit is contained in:
@@ -97,5 +97,10 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Load script as late as possible so DOM renders first -->
|
||||||
|
<script src="/lazyload17-8-2.min.js"></script>
|
||||||
|
<script>
|
||||||
|
var lazyLoadInstance = new LazyLoad({});
|
||||||
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@@ -27,7 +27,7 @@
|
|||||||
{% set rank = entry.rank %}
|
{% set rank = entry.rank %}
|
||||||
<td>
|
<td>
|
||||||
<a href="{{ links.url(artist) }}">
|
<a href="{{ links.url(artist) }}">
|
||||||
<div style='background-image:url("{{ images.get_artist_image(artist) }}")'>
|
<div class="lazy" data-bg="{{ images.get_artist_image(artist) }}"'>
|
||||||
<span class='stats'>#{{ rank }}</span> <span>{{ artist }}</span>
|
<span class='stats'>#{{ rank }}</span> <span>{{ artist }}</span>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
|
@@ -26,7 +26,7 @@
|
|||||||
{% set rank = entry.rank %}
|
{% set rank = entry.rank %}
|
||||||
<td>
|
<td>
|
||||||
<a href="{{ links.url(track) }}">
|
<a href="{{ links.url(track) }}">
|
||||||
<div style='background-image:url("{{ images.get_track_image(track) }}")'>
|
<div class="lazy" data-bg="{{ images.get_track_image(track) }}")'>
|
||||||
<span class='stats'>#{{ rank }}</span> <span>{{ track.title }}</span>
|
<span class='stats'>#{{ rank }}</span> <span>{{ track.title }}</span>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
{% set img = images.get_artist_image(entity) %}
|
{% set img = images.get_artist_image(entity) %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<td class='icon'><div style="background-image:url('{{ img }}')"></div></td>
|
<td class='icon'><div class="lazy" data-bg="{{ img }}"></div></td>
|
||||||
{% if entity is mapping and 'artists' in entity %}
|
{% if entity is mapping and 'artists' in entity %}
|
||||||
{% if settings['TRACK_SEARCH_PROVIDER'] %}
|
{% if settings['TRACK_SEARCH_PROVIDER'] %}
|
||||||
<td class='searchProvider'>{{ links.link_search(entity) }}</td>
|
<td class='searchProvider'>{{ links.link_search(entity) }}</td>
|
||||||
|
1
maloja/web/static/js/lazyload17-8-2.min.js
vendored
Normal file
1
maloja/web/static/js/lazyload17-8-2.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user