2016-04-13 27 views
0

Ben ... this, onlarla üzerine geldiğinizde değiştirmek görüntülerin tam sayfa ızgara benzer bir portföy web sitesi oluşturmak için (another example, the third screen!)Etkileşimli öğeler ızgarası nasıl oluşturulur?

çalışıyorum Ve şu anda ben görünen bir ham çözüme sahip gibi:

<img src="1.png" id="img" swap="2.png"/> 

// then in JS... 

$("#img").hover(function(){ 
    var _this = $(this); 
    var current = _this.attr("src"); 
    var swap = _this.attr("swap"); 
    _this.attr('src',swap).attr('swap',current); 
}); // 

code credit

Ama bu 1000 görüntüleri olan daha çok ölçeklenebilir çözüm ve diğer değil, src açılabilinir böylece tespit edildiği kendi benzersiz kimliği ile her, ben değilimNe yapmalı - plus Bunun farklı ekran boyutları/ekran kesme değerlerine nasıl tepki vereceğini bilmiyorum. Ve CSS'de arka plan görüntüsü güzel bir şekilde etkileşirken, etkileşime izin vermez ... belki de bir JS komut dosyası imleç konumu (?)

! Bu benim ilk projemdir, herhangi bir yardım takdir edilecektir :) (Codecademy çok korunaklı bir öğrenme ortamıdır ........)

+0

Sanal makinem 'başka bir örneğe gittiğimde biraz öldü'. Orada benim hayali 6GB hayali RAM için çok fazla şey oluyormuş gibi görünüyor. Kısacası, “bu”, daha yavaş cihazlarda veya yarı-sınırlı kaynaklara sahip olanlarda da kötü davranacaktır. –

+0

Eğer bunu CSS'de yapsaydınız, sadece farklı olmak için? –

cevap

0

Her görüntü için ids kullanmak ve bir işleyici oluşturmak zorunda değilsiniz .

bu ANDA sayfadaki her görüntüye geçerli olacaktır:

$("img").hover(function(){ 
    var _this = $(this); 
    var current = _this.attr("src"); 
    var swap = _this.attr("swap"); 
    _this.attr('src',swap).attr('swap',current); 
}); 

ve bunu her görüntüye tepki vereceği, sayfadan sonra eklenen hatta görüntüleri yüklenir:

$(document).on('hover', 'img', function() { 
    var _this = $(this); 
    var current = _this.attr("src"); 
    var swap = _this.attr("swap"); 
    _this.attr('src',swap).attr('swap',current); 
}); 

ekran için hesaba katmak boyutları ve diğer endişeleriniz, resimlerinizde sabit bir genişlik ve yükseklik ayarlamanız veya tüm resimlerinizin benzer çözünürlükte olduğundan emin olmanız gerekir.

Bunu, arka planlarla birlikte, bir kılavuz ızgarası oluşturarak ve daha sonra yukarıdaki işleyicilere benzer şekilde, vurgunun arka planını değiştirerek de yapabilirsiniz.

+0

Teşekkürler Yanıt için işaretle, Aslında ilk çözümü uyguladım ve işe yaradı ... Sabit genişlik/yükseklikler ile ilgili olarak, bu ems'de olurdu? Ekranı uçtan uca doldurmaya nasıl başardınız, HTML'den miras alınan bazı CSS'ler mi? Ayrıca ... ilk örnekte, renkli kare, yakınlaştırma/uzaklaştırma yaptığınızda konum değiştirir/değiştirir, bununla ilgili ipuçları var mı? xD teşekkürler! – user61871

+0

sorusu yanıtlandığından, cevabımı doğru seçebilmeniz harika olurdu! Diğer sorularınızda, her biri için birçok çözüm var. genişlikleri belirtebilirsiniz px (piksel), em (yazı tipi boyutuna göre),%. Ekranı dolduracak resim olmayan 'dolgu' blokları sağlamak için javascript'i kullanabilirsiniz. Çeşitli ekran çözünürlüklerini hedeflemek için medya sorgularını kullanabilirsiniz. Yakınlaştırmayı devre dışı bırakmanın yolları vardır. Bir yorumda ayrıntıya yer olmadığına dair çok sayıda cevap var. Hepsi web geliştiricisi olmanın bir parçası. Öğrenmesi gereken çok şey var! –