Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Picture tag can now handle an inside img tag if it exists (#225)
* Picture tag can now handle an inside img tag if it exists

* Add documentation

* Add tests
  • Loading branch information
srogier committed Sep 6, 2020
1 parent 584be41 commit 83fd88b
Show file tree
Hide file tree
Showing 6 changed files with 68 additions and 11 deletions.
12 changes: 12 additions & 0 deletions README.md
Expand Up @@ -236,6 +236,18 @@ Create _a broken_ picture element structure.

When _lozad_ loads this picture element, it will fix it.

If you want to use image placeholder (like low quality image placeholder), you can set a temporary `img` tag inside your `picture` tag. It will be removed when _lozad_ loads the picture element.

```html
<picture class="lozad" style="display: block; min-height: 1rem" data-iesrc="images/thumbs/04.jpg" data-alt="">
<source srcset="images/thumbs/04.jpg" media="(min-width: 1280px)">
<source srcset="images/thumbs/05.jpg" media="(min-width: 980px)">
<source srcset="images/thumbs/06.jpg" media="(min-width: 320px)">
<!-- you can define a low quality image placeholder that will be removed when the picture is loaded -->
<img src="_lqip_in_base_64==" />
</picture>
```

## Example with video

```html
Expand Down
15 changes: 12 additions & 3 deletions dist/lozad.es.js
@@ -1,4 +1,4 @@
/*! lozad.js - v1.15.0 - 2020-08-01
/*! lozad.js - v1.15.0 - 2020-09-05
* https://github.com/ApoorvSaxena/lozad.js
* Copyright (c) 2020 Apoorv Saxena; Licensed MIT */

Expand All @@ -15,7 +15,14 @@ const defaultConfig = {
threshold: 0,
load(element) {
if (element.nodeName.toLowerCase() === 'picture') {
const img = document.createElement('img');
let img = element.querySelector('img');
let append = false;

if (img === null) {
img = document.createElement('img');
append = true;
}

if (isIE && element.getAttribute('data-iesrc')) {
img.src = element.getAttribute('data-iesrc');
}
Expand All @@ -24,7 +31,9 @@ const defaultConfig = {
img.alt = element.getAttribute('data-alt');
}

element.append(img);
if (append) {
element.append(img);
}
}

if (element.nodeName.toLowerCase() === 'video' && !element.getAttribute('data-src')) {
Expand Down
15 changes: 12 additions & 3 deletions dist/lozad.js
@@ -1,4 +1,4 @@
/*! lozad.js - v1.15.0 - 2020-08-01
/*! lozad.js - v1.15.0 - 2020-09-05
* https://github.com/ApoorvSaxena/lozad.js
* Copyright (c) 2020 Apoorv Saxena; Licensed MIT */

Expand All @@ -21,7 +21,14 @@
threshold: 0,
load: function load(element) {
if (element.nodeName.toLowerCase() === 'picture') {
var img = document.createElement('img');
var img = element.querySelector('img');
var append = false;

if (img === null) {
img = document.createElement('img');
append = true;
}

if (isIE && element.getAttribute('data-iesrc')) {
img.src = element.getAttribute('data-iesrc');
}
Expand All @@ -30,7 +37,9 @@
img.alt = element.getAttribute('data-alt');
}

element.append(img);
if (append) {
element.append(img);
}
}

if (element.nodeName.toLowerCase() === 'video' && !element.getAttribute('data-src')) {
Expand Down
6 changes: 3 additions & 3 deletions dist/lozad.min.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 11 additions & 2 deletions src/lozad.js
Expand Up @@ -10,7 +10,14 @@ const defaultConfig = {
threshold: 0,
load(element) {
if (element.nodeName.toLowerCase() === 'picture') {
const img = document.createElement('img')
let img = element.querySelector('img')
let append = false

if (img === null) {
img = document.createElement('img')
append = true
}

if (isIE && element.getAttribute('data-iesrc')) {
img.src = element.getAttribute('data-iesrc')
}
Expand All @@ -19,7 +26,9 @@ const defaultConfig = {
img.alt = element.getAttribute('data-alt')
}

element.append(img)
if (append) {
element.append(img)
}
}

if (element.nodeName.toLowerCase() === 'video' && !element.getAttribute('data-src')) {
Expand Down
18 changes: 18 additions & 0 deletions test/index.js
Expand Up @@ -336,6 +336,24 @@ describe('lozad', () => {
const img = picture.children[1]
assert.strictEqual('alt text', img.getAttribute('alt'))
})

it('should use img tag if inside the picture', () => {
const className = 'test-class'
const observer = lozad('.' + className)
const picture = document.querySelectorAll('picture')[0]
picture.setAttribute('class', className)

const initialImage = document.createElement('img')
initialImage.setAttribute('customAttribute', 'custom value')
picture.appendChild(initialImage)
observer.observe()

const img = picture.children[1]
assert.strictEqual(
initialImage.getAttribute('customAttribute'),
img.getAttribute('customAttribute')
)
})
})

describe('toggle class', () => {
Expand Down

0 comments on commit 83fd88b

Please sign in to comment.