Ubah sumber gambar pada rollover menggunakan jQuery


443

Saya punya beberapa gambar dan gambar rollover mereka. Menggunakan jQuery, saya ingin menampilkan / menyembunyikan gambar rollover ketika peristiwa onmousemove / onmouseout terjadi. Semua nama gambar saya mengikuti pola yang sama, seperti ini:

Gambar asli: Image.gif

Gambar Rollover: Imageover.gif

Saya ingin menyisipkan dan menghapus bagian "over" dari sumber gambar di acara onmouseover dan onmouseout.

Bagaimana saya bisa melakukannya menggunakan jQuery?


Saya menulis cara-kecil dengan contoh untuk pemula, Ubah gambar dengan JavaScript (atau jQuery) . Ada juga contoh tanpa menggunakan jQuery.
gothy


10
Apa yang saya cari. Terima kasih telah mengirimkan Pertanyaan!
Samuel Meddows

Saya memiliki masalah seperti ini ( Pertanyaan Saya ). Jawaban dari pertanyaan ini sangat bagus tetapi di IE9 setiap kali Anda tombol, ada permintaan tambahan untuk gambar dan itu sangat buruk. Apakah ada yang punya jawaban lebih baik?
Iman

Jawaban:


620

Untuk menyiapkan siap:

$(function() {
    $("img")
        .mouseover(function() { 
            var src = $(this).attr("src").match(/[^\.]+/) + "over.gif";
            $(this).attr("src", src);
        })
        .mouseout(function() {
            var src = $(this).attr("src").replace("over.gif", ".gif");
            $(this).attr("src", src);
        });
});

Bagi mereka yang menggunakan sumber gambar url:

$(function() {
        $("img")
            .mouseover(function() {
               var src = $(this).attr("src");
               var regex = /_normal.svg/gi;
               src = this.src.replace(regex,'_rollover.svg');
               $(this).attr("src", src);

            })
            .mouseout(function() {
               var src = $(this).attr("src");
               var regex = /_rollover.svg/gi;
               src = this.src.replace(regex,'_normal.svg');
               $(this).attr("src", src);

            });
    });

7
Ini tidak berfungsi jika src adalah url absolut dengan a. di dalamnya (seperti www.example.com)
Kieran Andrews

8
Ini juga tidak berfungsi jika Anda menggunakan domain seperti www.over.com, atau memiliki overtempat lain di URI.
Benjamin Manns

32
bolehkah saya menyarankan untuk mengedit .replace final dengan .replace ("over.gif", ".gif");
Nathan Koop

2
Terima kasih telah memposting ini. Saya harap Anda tidak keberatan bahwa saya meletakkan ini di blog saya. Blog saya seperti "buku catatan" dan "barang masuk" saya ketika saya melupakan sesuatu.
wenbert

1
Tidak perlu menggunakan metode ".match (/[^\.[+/)" dan dengan Regex. ".Replace (". Gif "," over.gif ") sudah cukup untuk bekerja
Navigatron

114

Saya tahu Anda bertanya tentang menggunakan jQuery, tetapi Anda dapat mencapai efek yang sama di browser yang menonaktifkan JavaScript menggunakan CSS:

#element {
    width: 100px; /* width of image */
    height: 200px; /* height of image */
    background-image: url(/path/to/image.jpg);
}

#element:hover {
    background-image: url(/path/to/other_image.jpg);
}

Ada deskripsi yang lebih panjang di sini

Namun yang lebih baik adalah menggunakan sprite: simple-css-image-rollover


1
ya, tetapi sedikit lebih sulit untuk melakukan ini pada elemen IMAGE :) Selain itu, CSS berarti pemisahan konten dari presentasi. Jika Anda melakukan ini, Anda bergabung dengan hal-hal itu;) Anda tidak dapat memiliki ini untuk situs besar, kan?
Ionuț Staicu

Saya setuju dengan Anda tentang css, tetapi tampaknya penulis pertanyaan menginginkan solusi umum yang berlaku untuk beberapa gambar sekaligus.
Jarrod Dixon

9
Solusi ini adalah opsi yang paling disukai, kecuali jika Anda melakukan beberapa efek. Saya sedang memikirkan hal yang sama persis +1
Angel.King.47

6
Itu adalah solusi terbaik. Untuk menghindari menunggu gambar baru (permintaan jaringan) gunakan image.jpg tunggal dan bermain dengan posisi latar belakang untuk menunjukkan / menyembunyikan yang baik.
kheraud

2
@kheraud Memindahkan gambar tunggal adalah solusi yang baik, tetapi apakah itu yang terbaik atau tidak tergantung pada ukuran gambar. Misalnya, di internet lambat, mengunduh dua gambar lebar 1920px dalam satu file raksasa akan memakan waktu lama. Untuk ikon dan gambar kecil meskipun berfungsi dengan baik.
DACrosby

63

Jika Anda memiliki lebih dari satu gambar dan Anda memerlukan sesuatu yang umum yang tidak bergantung pada konvensi penamaan.

HTML

<img data-other-src="big-zebra.jpg" src="small-cat.jpg">
<img data-other-src="huge-elephant.jpg" src="white-mouse.jpg">
<img data-other-src="friendly-bear.jpg" src="penguin.jpg">

JavaScript

$('img').bind('mouseenter mouseleave', function() {
    $(this).attr({
        src: $(this).attr('data-other-src') 
        , 'data-other-src': $(this).attr('src') 
    })
});

1
Ini untuk saya. Hanya ingat untuk meletakkan javascript di dalam fungsi untuk menjalankannya yaitu ketika DOM siap "$ (function () {});"
Mischa

Sebenarnya itu memicu ketika halaman masih memuat, dan ketika kursor mouse Anda benar-benar di atas pemilih itu menggantikan url sehingga efeknya terbalik
Mike

57
    /* Teaser image swap function */
    $('img.swap').hover(function () {
        this.src = '/images/signup_big_hover.png';
    }, function () {
        this.src = '/images/signup_big.png';
    });

4
Perlu diingat bahwa dengan cara ini akan berarti bahwa pengguna akan melihat jeda pada hover pertama saat browser mengambil gambar.
Tyson

1
@Tyson Benci untuk naik kereta terlambat, tetapi Anda dapat preload gambar dengan baik melalui Javascript atau CSS
cbr

Tidak bekerja di Chrome 37 juga. $ (ini) .attr ("src", src) berfungsi dengan baik.
Le Droid

25

Solusi umum yang tidak membatasi Anda untuk "gambar ini" dan "gambar itu" hanya mungkin menambahkan tag 'onmouseover' dan 'onmouseout' ke kode HTML itu sendiri.

HTML

<img src="img1.jpg" onmouseover="swap('img2.jpg')" onmouseout="swap('img1.jpg')" />

JavaScript

function swap(newImg){
  this.src = newImg;
}

Bergantung pada pengaturan Anda, mungkin sesuatu seperti ini akan bekerja lebih baik (dan membutuhkan lebih sedikit modifikasi HTML).

HTML

<img src="img1.jpg" id="ref1" />
<img src="img3.jpg" id="ref2" />
<img src="img5.jpg" id="ref3" />

JavaScript / jQuery

// Declare Arrays
  imgList = new Array();
  imgList["ref1"] = new Array();
  imgList["ref2"] = new Array();
  imgList["ref3"] = new Array();

//Set values for each mouse state
  imgList["ref1"]["out"] = "img1.jpg";
  imgList["ref1"]["over"] = "img2.jpg";
  imgList["ref2"]["out"] = "img3.jpg";
  imgList["ref2"]["over"] = "img4.jpg";
  imgList["ref3"]["out"] = "img5.jpg";
  imgList["ref3"]["over"] = "img6.jpg";

//Add the swapping functions
  $("img").mouseover(function(){
    $(this).attr("src", imgList[ $(this).attr("id") ]["over"]);
  }

  $("img").mouseout(function(){
    $(this).attr("src", imgList[ $(this).attr("id") ]["out"]);
  }

21
$('img.over').each(function(){
    var t=$(this);
    var src1= t.attr('src'); // initial src
    var newSrc = src1.substring(0, src1.lastIndexOf('.'));; // let's get file name without extension
    t.hover(function(){
        $(this).attr('src', newSrc+ '-over.' + /[^.]+$/.exec(src1)); //last part is for extension   
    }, function(){
        $(this).attr('src', newSrc + '.' + /[^.]+$/.exec(src1)); //removing '-over' from the name
    });
});

Anda mungkin ingin mengubah kelas gambar dari baris pertama. Jika Anda membutuhkan lebih banyak kelas gambar (atau jalur berbeda) yang dapat Anda gunakan

$('img.over, #container img, img.anotherOver').each(function(){

dan seterusnya.

Seharusnya berhasil, saya tidak mengujinya :)


2
+1 Doh, lupa tentang pembantu acara hover! Dan saran yang bagus tentang menambahkan kelas untuk gambar - benar-benar adalah praktek terbaik :)
Jarrod Dixon

1
Itu solusi yang jauh lebih baik karena cache sumber gambar lama.
trante

Bagian negatifnya adalah, jika gambar ada di bagian bawah halaman dan ada 10-20 gambar maka tata letak menjadi aneh.
trante

13

Saya berharap untuk oneber one liner seperti:

$("img.screenshot").attr("src", $(this).replace("foo", "bar"));

6

Jika solusi yang Anda cari adalah tombol animasi, maka yang terbaik yang dapat Anda lakukan untuk meningkatkan kinerja adalah kombinasi sprite dan CSS. Sprite adalah gambar besar yang berisi semua gambar dari situs Anda (tajuk, logo, tombol, dan semua dekorasi yang Anda miliki). Setiap gambar yang Anda gunakan menggunakan permintaan HTTP, dan semakin banyak permintaan HTTP semakin banyak waktu yang diperlukan untuk memuat.

.buttonClass {
    width: 25px;
    height: 25px;
    background: url(Sprite.gif) -40px -500px;
}
.buttonClass:hover {
    width: 25px;
    height: 25px;
    background: url(Sprite.gif) -40px -525px;
}

The 0px 0pxkoordinat akan pojok kiri dari sprite Anda.

Tetapi jika Anda sedang mengembangkan beberapa album foto dengan Ajax atau sesuatu seperti itu, maka JavaScript (atau kerangka kerja apa pun) adalah yang terbaik.

Selamat bersenang-senang!


4
$('img').mouseover(function(){
  var newSrc = $(this).attr("src").replace("image.gif", "imageover.gif");
  $(this).attr("src", newSrc); 
});
$('img').mouseout(function(){
  var newSrc = $(this).attr("src").replace("imageover.gif", "image.gif");
  $(this).attr("src", newSrc); 
});

4

Sementara mencari solusi beberapa waktu lalu, saya menemukan skrip yang mirip dengan di bawah ini, yang setelah beberapa penyesuaian saya berhasil untuk saya.

Ini menangani dua gambar, yang hampir selalu default ke "off", di mana mouse dari gambar (image-example_off.jpg), dan sesekali "on", di mana untuk saat mouse melayang-layang, gambar alternatif yang diperlukan ( image-example_on.jpg) ditampilkan.

<script type="text/javascript">        
    $(document).ready(function() {        
        $("img", this).hover(swapImageIn, swapImageOut);

        function swapImageIn(e) {
            this.src = this.src.replace("_off", "_on");
        }
        function swapImageOut (e) {
            this.src = this.src.replace("_on", "_off");
        }
    });
</script>

Saya menyadari bahwa fungsi di atas akan mengeksekusi untuk semua gambar dalam DOM karena saat ini dikodekan. Memasok konteks lebih lanjut akan membuatnya fokus efek ke elemen img tertentu.
Kristopher Rout

3
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>JQuery</title>
<script src="jquery.js" type="text/javascript"> </script>
<style type="text/css">
    #box{
        width: 68px;
        height: 27px;
        background: url(images/home1.gif);
        cursor: pointer;
    }
</style>

<script type="text/javascript">

$(function(){

    $('#box').hover( function(){
        $('#box').css('background', 'url(images/home2.gif)');

    });
    $('#box').mouseout( function(){
        $('#box').css('background', 'url(images/home1.gif)');

    });

});
</script>
</head>

<body>
<div id="box" onclick="location.href='index.php';"></div>
</body>
</html>

2

Saya telah membuat sesuatu seperti kode berikut ini :)

Ini hanya berfungsi, ketika Anda memiliki file kedua bernama _hover, misalnya, facebook.pngdanfacebook_hover.png

$('#social').find('a').hover(function() {
    var target = $(this).find('img').attr('src');
    //console.log(target);
    var newTarg = target.replace('.png', '_hover.png');
    $(this).find('img').attr("src", newTarg);
}, function() {
    var target = $(this).find('img').attr('src');
    var newTarg = target.replace('_hover.png', '.png');
    $(this).find('img').attr("src", newTarg);
});

1
<img src="img1.jpg" data-swap="img2.jpg"/>



img = {

 init: function() {
  $('img').on('mouseover', img.swap);
  $('img').on('mouseover', img.swap);
 }, 

 swap: function() {
  var tmp = $(this).data('swap');
  $(this).attr('data-swap', $(this).attr('src'));
  $(this).attr('str', tmp);
 }
}

img.init();

1

Diadaptasi dari kode Richard Ayotte - Untuk menargetkan img dalam daftar ul / li (ditemukan melalui kelas div wrapper di sini), sesuatu seperti ini:

$('div.navlist li').bind('mouseenter mouseleave', function() {    
    $(this).find('img').attr({ src: $(this).find('img').attr('data-alt-src'), 
    'data-alt-src':$(this).find('img').attr('src') }
); 
Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.