Menue mit Browsertest Hilfe

smily

Mitglied
Hallo all,

ich habe ein Menue. Mein Problem ist es funktioniert aber leider nur im IE und soll für andere Browser wie Netscape, Mozilla, Opera ua auch funktionieren. Habe aber leider keine Ahnung wie ich das umsetzen soll, da ich von JavaScript keine Ahnung habe, d.h ich habe das Menue im Net gefunden.

Vielleicht kann mir jemand helfen, da irgendwie einen Browsercheck einzubauen. Habe im Internet schon gesucht aber leider nichts gefunden.

Der Script:
Code:
var mnpMenuTop = null;
var mnpMenuKill = null;
var mnpMenuPopup = null;
var mnpMenuUrl = null;
var mnpMenuParent = null;
var mnpMenuShadows = new Array();
var mnpMenuDirSave = "LTR";
var mnpMenuCTSave = false;
var mnpMenuRenderStart = null;
var mnpMenuShadowsEnabled = true;

window.attachEvent("onload", mnpMenuInit);
	
function mnpMenuDir()
{ return "LTR";}
	
function mnpMenuCT()
{ return false;}

function mnpMenuInit()
{
  try
     { mnpMenuDirSave = mnpMenuDir();
       mnpMenuCTSave = mnpMenuCT();
     }
   catch(e)
      {return;}
    mnpMenuTop = document.getElementById("mnpMenuTop");
    mnpMenuUrl = mnpMenuTop.getAttribute("url");
    mnpMenuParent = mnpMenuTop.getAttribute("parent");
    mnpMenuAttach(mnpMenuTop);
}

function mnpPage(label, url, target, menu, linkID)
{   this.label = label;
    this.url = url;
    this.target = target;
    this.menu = menu;
    this.linkID = linkID;
}

function mnpMenuEnter()
{ if (mnpMenuKill)
  {window.clearTimeout(mnpMenuKill);
    mnpMenuKill = null;}
}

function mnpMenuLeave()
{mnpMenuKill = window.setTimeout("mnpMenuKiller()", 200);}

function mnpMenuKiller()
{  mnpKillMenu(mnpMenuTop.getAttribute("currentMenu"));
   mnpMenuTop.removeAttribute("currentMenu");}

function mnpMenuAttach(el)
{ el.attachEvent("onmouseenter", mnpMenuEnter);
  el.attachEvent("onmouseleave", mnpMenuLeave);
  var divs = el.getElementsByTagName("DIV");
  var t = divs.length;
  for (var i=0; i < t; i++)
     { var div = divs.item(i);
       if (div.className == "mnpMenuRow")
          {div.attachEvent("onmouseenter", mnpMenuMouseover);
	div.attachEvent("onmouseleave", mnpMenuMouseout);
	div.attachEvent("onmousedown", mnpMenuMousedown);
	div.attachEvent("onmouseup", mnpMenuMouseup);
	div.setAttribute("save-background", div.style.background);
	div.setAttribute("save-border", div.style.borderColor);
	var a = div.getElementsByTagName("A");
	if (a.length > 0)
	{ var a0 = a[0];
	  if (a0.getAttribute("aoff"))
	  a0.outerHTML = a0.innerHTML;
	  else
	  {div.setAttribute("status", a0.href);
	   div.attachEvent("onclick", mnpMenuClick);}
	}
	if (div.getAttribute("menu"))
	{var imgs = div.getElementsByTagName("IMG");
	     if (imgs.length > 0)
	        {var img = imgs[0];
	         img.style.visibility = "visible";}
	     else
                         {var x;
		if (mnpMenuDirSave == "LTR")
		 x = (div.offsetWidth - 10) + "px";
		else if (mnpMenuTop.contains(div))
		 x = "4px";
		else
		 x = "6px";
	          var img = "<IMG src='arrow" + mnpMenuDirSave + ".gif' border='0' class='mnpMenuArrow' style='left: " + x + "' />";
	         div.insertAdjacentHTML("afterBegin", img);
	        }
	}
          }
     }
}

function mnpMenuClick()
{ var div = window.event.srcElement;
  var a = div.getElementsByTagName("A");
  if (a.length == 0) return;
  if (window.event.shiftKey)
   { var target = a[0].target;
     a[0].target = "_new";// zugriff auf iframe
     a[0].click();
     a[0].target = target;
   }
   else
   a[0].click();
}

function mnpKillMenu(id)
{ if (id == null) return;
  var menu = document.getElementById(id);
  var current = menu.getAttribute("currentMenu");
   if (current) 
      {mnpKillMenu(current);
       menu.removeAttribute("currentMenu");
      }
   var temp = mnpMenuShadows[id];
   if (temp)
      { var i;
        var tempLength = temp.length;
        for (i=0; i< tempLength; i++)
        if (temp[i])
           document.body.removeChild(temp[i]);
           mnpMenuShadows[id] = null;
       }
        var parent = document.getElementById(menu.getAttribute("parentMenu"));// speichern der hintergründe
        var rows = parent.getElementsByTagName("DIV");
        var rLength = rows.length;
        for (var i=0; i< rLength; i++)
             { var row = rows.item(i);
               var m = row.getAttribute("menu");
	if (m == id)
	{row.style.background = row.getAttribute("save-background");
	 row.style.borderColor = row.getAttribute("save-border");
	}
             }
             show_elements("SELECT", menu);
             show_elements("OBJECT", menu);
             menu.style.display = "none";
}
function mnpMenuOpen(id, parentId, x, y)
{ var parent;
 try
 {parent = document.getElementById(parentId);}
 catch(e)
  {return;}
  var current = parent.getAttribute("currentMenu");
  if (id == current) return;
  mnpKillMenu(current);
  if (id)
    parent.setAttribute("currentMenu", id);
  else
  {parent.removeAttribute("currentMenu");
    return;}
   var div = document.getElementById(id);
    if (div == null)
    { var menu = eval("new " + id + "()");
      var html = "<DIV id='" + id + "' class='mnpMenuSub' dir='" + mnpMenuDirSave + "'>"
           html += "<DIV style='display: none; background: #F1F1F1; border-color: #F1F1F1'><IMG src='arrowLTR.gif' /></DIV>";
           html += "<DIV>";
      var isThisPage = false;
      var mLength = menu.items.length;
      for (var i=0; i< mLength; i++)
          { var item = menu.items[i];
            var url = item.url;
           if (url == mnpMenuUrl)
	{isThisPage = true;
	  break;}
          }
      for (var i=0; i< mLength; i++)
          {var item = menu.items[i];
           var label = item.label;
           var re = /'/g;
           var url = item.url;
            if (url)
            url = url.replace(re, "'");
            var target = item.target;
            var submenu = item.menu;
            var linkID = item.linkID;
            html += "<DIV";
             if (submenu)
             html += " menu='" + submenu + "'";
             if (url)
	{html += " class='mnpMenuRow'";
	  if (url == mnpMenuUrl)
	      html += " style='border-color: #999999; background: white; cursor: default";
	  else if (!isThisPage && (url == mnpMenuParent))
	      html += " style='border-color: #999999; background: white";//#F1F1F1
	   else
	      html += " style='border-color: white; background: white";//#F1F1F1;#F1F1F1
	if (mnpMenuDirSave == "LTR")
	html += "; padding-left: 11px";
	else
		html += "; padding-right: 11px";
				html += "'";
			}
			else
				html += " class='mnpMenuLabel'";
			html += ">";
			if (url && (url != mnpMenuUrl))
			{
				var targetAttr = target == "" ? "" : " target='" + target + "'";
				if (mnpMenuCTSave)
					html += "<A href='" + url + "'" + targetAttr + " LinkArea='Left Nav' LinkID='Flyout" + linkID + "'>" + label + "</A>";
				else
					html += "<A href='" + url + "'" + targetAttr + ">" + label + "</A>";
			}
			else
				html += "<SPAN>" + label + "</SPAN>";
			html += "</DIV>";
		}
		html += "</DIV>";
		html += "<DIV style='display:none; background: #F1F1F1; border-color: #F1F1F1'><IMG src='arrowLTR.gif'/></DIV>";
		html += "</DIV>";
		document.body.insertAdjacentHTML("afterBegin", html);
		var div = document.getElementById(id);
		var sa = div.childNodes.item(1);
		var max = 0;
		var saLength = sa.childNodes.length;
		for (var i=0; i<saLength; i++)
		{
			var it = sa.childNodes.item(i).childNodes.item(0);
			var w = it.offsetWidth;
			if (w > max) max = w;
		}
		max += 34;
		if (max < 100) max = 100;
		else if (max > 410) max = 410;
		div.style.width = max + "px";
		for (var i=0; i< saLength; i++)
		{
			var it = sa.childNodes.item(i);
			if (it.className == "mnpMenuRow")
				it.style.width = (max - 6) + "px";
		}
		mnpMenuAttach(div);
		div.setAttribute("parentMenu", parentId);
	}
	else
	{
		div.style.display = "";
	}
	var bodyHeight = document.body.clientHeight;
	var bodyTop = document.body.scrollTop;
	var bodyWidth = document.body.clientWidth;
	var bodyLeft = document.body.scrollLeft;
	var up = div.children.item(0);
	var box = up.nextSibling;
	var down = box.nextSibling;
	up.style.display = "none";
	down.style.display = "none";
	box.style.height = "";

	if (mnpMenuDirSave == "RTL") // abstand untemenue
		x -= div.offsetWidth;
	div.style.left = x + "px";
	div.style.top = y + "px";
	div.style.zIndex = parent.style.zIndex + 10;
	if (div.offsetLeft + div.offsetWidth > bodyWidth + bodyLeft)
		document.body.scrollLeft = div.offsetLeft + div.offsetWidth - bodyWidth;
	hide_elements("SELECT", div);
	hide_elements("OBJECT", div);
	
	if (mnpMenuShadowsEnabled) //Schatten einschalten
	{
		mnpMenuShadows[id] = mnpMenuShadow(div, "#666666", 4, div.offsetWidth, div.offsetHeight);
		mnpMenuRenderStart = mnpMenuTime();
	}
}
function mnpMenuPt(el)
{
	this.left = 0;
	this.top = 0;
	while (el)
	{
		this.left += el.offsetLeft;
		this.top += el.offsetTop;
		el = el.offsetParent;
	}
}
// mausfunktion
function mnpMenuMouseover()
{
	var div = window.event.srcElement;
	var status = div.getAttribute("status");
	if (status) window.status = status;
	div.style.background = "#CCCCCC";
	div.style.borderColor = "#999999";
	var pt = new mnpMenuPt(div);
	var x;
	if (mnpMenuDirSave == "LTR")
		x = pt.left + div.offsetWidth - 1;
	else
		x = pt.left + 2; // Abstand von links
	var y = pt.top - 3; // Abstand von oben
	var menu = div.getAttribute("menu");
	if (menu)
		menu = "'" + menu + "'";
	else
		menu = "null";
	if (mnpMenuPopup)
		window.clearTimeout(mnpMenuPopup);
	var parent = div.parentElement.parentElement;
	mnpMenuPopup = window.setTimeout("mnpMenuOpen(" + menu + ", '" + parent.id + "', " + x + ", " + y + ")", 200);
}

function mnpMenuMouseout()
{
	var div = window.event.srcElement;
	window.status = "";
	var menu = div.getAttribute("menu");
	if (menu != null && menu == div.parentElement.parentElement.getAttribute("currentMenu"))
	{
		div.style.background = "#CCCCCC";
		div.style.borderColor = "#CCCCCC";
	}
	else
	{
		div.style.background = div.getAttribute("save-background");
		div.style.borderColor = div.getAttribute("save-border");
	}
	if (mnpMenuPopup)
	{
		window.clearTimeout(mnpMenuPopup);
		mnpMenuPopup = null;
	}
}

function mnpMenuMousedown()
{
	var div = window.event.srcElement;
	if (div.tagName != "DIV") div = div.parentElement;
	div.style.background = "#999999";
}

function mnpMenuMouseup()
{
	var div = window.event.srcElement;
	if (div.tagName != "DIV") div = div.parentElement;
	div.style.background = div.getAttribute("save-background");
}
//
function mnpMenuTime()
{
	var time = new Date();
	return time.valueOf();
}
// Schatten
function mnpMenuShadow(el, color, size, width, height)
{
	var temp = new Array();
	var i;
	for (i=size; i>0; i--)
	{
		var rect = document.createElement('div');
		var rs = rect.style
		rs.position = 'absolute';
		rs.left = (el.style.posLeft + i) + 'px';
		rs.top = (el.style.posTop + i) + 'px';
		rs.width = width + 'px';
		rs.height = height + 'px';
		rs.zIndex = el.style.zIndex - i;
		rs.backgroundColor = color;
		var opacity = 1 - i / (i + 1);
		rs.filter = 'alpha(opacity=' + (100 * opacity) + ')';
		document.body.appendChild(rect);
		temp[i] = rect;
	}
	return temp;
}

function hide_elements(tagName, menu)
{
	windowed_element_visibility(tagName, -1, menu)
}

function show_elements(tagName, menu)
{
	windowed_element_visibility(tagName, +1, menu)
}

function windowed_element_visibility(tagName, change, menu)
{
	var els = document.getElementsByTagName(tagName)
	var i
	var rect = new element_rect(menu)
	var elsLength = els.length;
	for (i=0; i < elsLength; i++)
	{
		var el = els.item(i)
		if (elements_overlap(el, rect))
		{
			if (el.visLevel)
				el.visLevel += change
			else
				el.visLevel = change
			if (el.visLevel == -1 && change == -1)
			{
				el.visibilitySave = el.style.visibility;
				el.style.visibility = "hidden";
			}
			else if (el.visLevel == 0 && change == +1)
			{
				el.style.visibility = el.visibilitySave;
			}
		}
	}
}

function element_rect(el)
{
	var left = 0
	var top = 0
	this.width = el.offsetWidth
	this.height = el.offsetHeight
	while (el)
	{
		left += el.offsetLeft
		top += el.offsetTop
		el = el.offsetParent
	}
	this.left = left;
	this.top = top;
}

function elements_overlap(el, rect)
{
	var r = new element_rect(el);
	return ((r.left < rect.left + rect.width) && (r.left + r.width > rect.left) && (r.top < rect.top + rect.height) && (r.top + r.height > rect.top))
}
das Menue:
Code:
<DIV class="mnpMenuTop" id="mnpMenuTop" dir="ltr" style="BORDER-COLOR: #f1f1f1;OVERFLOW-X: hidden; WIDTH: 126px" url="default.htm">
<DIV class="mnpInherit">
<DIV menu="m1" class="mnpMenuRow" style="BORDER-COLOR: #999999; BACKGROUND: #ffffff; OVERFLOW-X: hidden; WIDTH: 119px; CURSOR: default;">
<IMG class="mnpMenuArrow" title="" style="LEFT: 100px; VISIBILITY: hidden" height="7" alt="*" src="nimage/arrowLTR.gif" border="0">
<A href="kompetenz.htm" aoff="yes" LinkID="Flyout_S1_Node1" LinkArea="Left Nav">Kompetenzen</A></DIV>
<DIV menu="m2" class="mnpMenuRow" style="BORDER-COLOR: #999999; BACKGROUND: #FFFFFF; OVERFLOW-X: hidden; WIDTH: 119px; margin-top:7px;">
<IMG class="mnpMenuArrow" title="" style="LEFT: 100px; VISIBILITY: hidden" height="7" alt="*" src="arrowLTR.gif" border="0">
<A href="loesungen.htm" LinkID="Flyout_S2_Node1" LinkArea="Left Nav">Lösungen</A>
</DIV>
</DIV>
</DIV>


Wäre echt super, wenn mir da jemand helfen könnte.

smily
 
Dieser Code funktioniert nicht einmal im IE... wäre schön, wenn du etwas posten könntest, was wenigstens irgendwo funktioniert, damit man sieht, was funktionieren soll.(oder poste nen Link zu einem lauffähigem Beispiel).
 
Oh Sorry,
ich habe vergessen die restlichen Dateien dazu zu schreiben.
Habe jetzt alles in der Textdatei menue.txt hineingeschrieben.
Ich hoffe Ihr könnt mir helfen.

Danke
Smily
 

Anhänge

Dieses Menu wurde offensichtlich nur für den IE geschrieben..... dass es woanders nicht funktioniert, ist somit kein Fehler, sondern Absicht oder aus Bequemlichkeit in Kauf genommen.

Ich hab grad leider keine Zeit, um einen Reparaturversuch zu starten:(
 
Hallo Sven,

ich danke dir das Du Dich meiner angenommen hast.
Hast Du zufällig ein ähnliches Menue
Wie gesagt, habe nicht viel Ahnung von JavaScript und verstehe somit auch den Quelltext nicht.

Danke Smily
 
ok das war nichts,
verstehe von dem Code leider nur Bahnhof.
Kann es also kaum gebrauchen, was auf den Seiten vorhanden ist.

Trotzdem danke

Smily
 

Neue Beiträge

Zurück