Javascript Responsive Images with MatchMedia

Lee Saxon

Member
Jan 31, 2010
91
0
61
I'm trying to work out a short and simple solution to responsive images (only loading smaller or larger images, depending on screen size) using Javascript's MatchMedia. (Yes, I'm aware this can sorta be done in CSS3 by using background-image, but that's hack-y and not ideal for me).

I've been using the following script for rollover and onClick types of image changes. I like it because (unlike most scripts I've found) it doesn't require a separate function to be written out for every single set of images:

Code:
function imageOn(imageName) {
    if (document.images) {
        currentImage = document.images[imageName];
        currentImage.src = imageName + "-version2.jpg";
    }
}

It works with this HTML:

Code:
<img name="test-image" src="test-image-version1.jpg" onClick="imageOn('test-image')">

Now, I'm Javascript illiterate, but it seems like if you replaced the onClick HTML with something static (but what?) this script could be dropped into this:

Code:
var screencheck = window.matchMedia("(min-width: 32em)");

if (screencheck.matches) {
/*ImageOn function*/
}
 
Last edited:

Ken g6

Programming Moderator, Elite Member
Moderator
Dec 11, 1999
16,360
4,066
75
onload and onresize?

But what is it about CSS3 background images that you find "hack-y"? Do you have to use <img> in your HTML? If not, try @media queries with background-image on a div.
 
sale-70-410-exam    | Exam-200-125-pdf    | we-sale-70-410-exam    | hot-sale-70-410-exam    | Latest-exam-700-603-Dumps    | Dumps-98-363-exams-date    | Certs-200-125-date    | Dumps-300-075-exams-date    | hot-sale-book-C8010-726-book    | Hot-Sale-200-310-Exam    | Exam-Description-200-310-dumps?    | hot-sale-book-200-125-book    | Latest-Updated-300-209-Exam    | Dumps-210-260-exams-date    | Download-200-125-Exam-PDF    | Exam-Description-300-101-dumps    | Certs-300-101-date    | Hot-Sale-300-075-Exam    | Latest-exam-200-125-Dumps    | Exam-Description-200-125-dumps    | Latest-Updated-300-075-Exam    | hot-sale-book-210-260-book    | Dumps-200-901-exams-date    | Certs-200-901-date    | Latest-exam-1Z0-062-Dumps    | Hot-Sale-1Z0-062-Exam    | Certs-CSSLP-date    | 100%-Pass-70-383-Exams    | Latest-JN0-360-real-exam-questions    | 100%-Pass-4A0-100-Real-Exam-Questions    | Dumps-300-135-exams-date    | Passed-200-105-Tech-Exams    | Latest-Updated-200-310-Exam    | Download-300-070-Exam-PDF    | Hot-Sale-JN0-360-Exam    | 100%-Pass-JN0-360-Exams    | 100%-Pass-JN0-360-Real-Exam-Questions    | Dumps-JN0-360-exams-date    | Exam-Description-1Z0-876-dumps    | Latest-exam-1Z0-876-Dumps    | Dumps-HPE0-Y53-exams-date    | 2017-Latest-HPE0-Y53-Exam    | 100%-Pass-HPE0-Y53-Real-Exam-Questions    | Pass-4A0-100-Exam    | Latest-4A0-100-Questions    | Dumps-98-365-exams-date    | 2017-Latest-98-365-Exam    | 100%-Pass-VCS-254-Exams    | 2017-Latest-VCS-273-Exam    | Dumps-200-355-exams-date    | 2017-Latest-300-320-Exam    | Pass-300-101-Exam    | 100%-Pass-300-115-Exams    |
http://www.portvapes.co.uk/    | http://www.portvapes.co.uk/    |