Moin Leudde,
folgendes Problem habe ich:
Ich kann die Opacity von einem <div> auf "root"-Ebene im IE verändern, sobald ich aber ein unterelement versuche zu verändern, macht das nix mehr, während z.B. visibility = 'hidden' dieses Unterelements problemlos funktioniert:
Hier mal die Definition:
<div id="Q1">
<div id="Q1Button1"><a href="#" onClick="javascript:Button(1,1); return false;">Button 1</a></div>
<div id="Q1Button2"><a href="#" onClick="javascript:Button(1,2); return false;">Button 2</a></div>
</div>
Die Javascript-Schnipsel dazu sehen wie folgt aus:
function Button(q, b) {
eval("b1 = 'Q" + q + "Button1'"); eval("b2 = 'Q" + q + "Button2'");
if (b == 1) { opacitylayer(b1, 1); opacitylayer(b2, 0.3); }
else { opacitylayer(b1, 0.3); opacitylayer(b2, 1); }
// ...
}
In einer separaten Bibliothek sind folgende Routinen definiert:
function opacitylayer(a, o) {
var x = new getObj(a);
if (x.style) {
x.style.opacity = o;
x.style.MozOpacity = o;
x.style.filter = "Alpha(opacity=" + eval(o * 100) + ")";
}
}
Die Funktion getObj ist eine standard-routine um das Element abhängig von dem Browser zu bekommen, und die funktioniert auch.
Rufe ich
opacitylayer('Q1', 0.3)
auf, so klappt es in allen Browsern, rufe ich
opacitylayer('Q1Button1', 0.3)
auf, so geht es bei FF und Safari, nicht aber beim IE, die Opacity verändert sich nicht.
Mache ich zum Test in der Routine aber ein
s.style.visibility = 'hidden'
So verschwindet auch das Element aus dem verschachtelten <div> (sprich mein Button)...
So....irgendwie tappe ich da im dunkeln und habe keine Ahnung, wo das Problem liegt...Irgendwelche Ideen, Tipps oder Work-a-rounds?
Danke, Carsten