2

我试图用子菜单制作导航栏,但我一直在获取 dropMenu 未定义,当我将鼠标悬停在两个巴黎链接上时,我得到 Uncaught TypeError: Cannot read property 'style' of null 任何想法这是我的代码 html

<html>
<link type="text/css"  rel="stylesheet" href="vacation.css"/>
<head>
<title>Paris</title>
</head>
<body>
<div id="menus">
<div id ="parismenu">
<a href="#" onmouseover="dropMenu('dropmenu1')">Paris</a>
<div id="dropmenu1" class="dropmenus">
<a href="#">apple</a>
</div>
</div>
<div id ="disneymenu">
<a href="#" onmouseover="dropMenu('dropmenu2')">Paris</a>
<div id="dropmenu2" class="dropmenus">
<a href="#">apple</a>
</div>
</div>
</div>
</body>
<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jqueryui/1.10.3/jquery-ui.min.js"></script>
 <script type="text/javascript" src="vacation.js"></script>
  </html>

css

div#menus{
margin-left:16px;
 }
 div#menus> div{
 float:left;
 margin:0px 20px;
 }
 div.dropmenus{
 display:none;
 position:absolute;
 top:100px;
 width:120px;
 background:teal;
 z-index:2;
 padding:4px;
 border: blue 3px solid;
 border-top:none;
 border-radius:5px 5px 5px 5px;
 }
 div.dropmenus>a{
 display:block;
 margin:4px;
 padding:7px;
 font-size:14px;
 text-decoration:none;
 background:blue;
 border-radius:3px;
 color:red;
 }
 div#dropmenu1{
 left:24px;
 }
 div#dropmenu2{
 left:116px;
 }

javascript

 var fade=function(){
 return{
 init:function(id,flag,target){
 this.elem=document.ElementById(id);
 clearInterval(this.elem.si);
 this.target=target ? target : flag ? 100 : 0;
 this.flag = flag||1;
 this.alpha = this.elem.stle.opacity ? parseFloat(this.elem.style.opacity) * 100 : 0;
 this.elem.si=setIntterval(function(){fade.fadep()},20);
 },
 fadep:function(){
 if(this.alpha==this.target){
 clearInterval(this.elem.si);
 }
 else{
 var value=Math.round(this.alpha + ((this.target - this.alpha) * .05)) +(-1 * this.flag);
 this.elem.style.opacity=value/100;
 this.elem.style.filter='alpha(opacity=' + value + ')';
 this.alpha=value
 }}}}();

 var menu= ["dropmenu1","dropmenu2","dropmenu3"];
 function dropMenu(x){
 for(var m in menu){
 if(menu[m] != x){
 document.getElementById(menu[m]).style.display="none";
 }}
 if(document.getElementById(x).style.diplay=="block"){
 fade.init(x,1);
  }
 else{
 fade.init(x,0)}}
4

3 回答 3

0

您的数组包含三个 id 而您的 html 只有前两个 - 所以

document.getElementById(menu[m])

如果 m === 2 将是未定义的

所以你需要从菜单数组中删除“dropmenu3”。

另外,这一行:

this.elem=document.ElementById(id);

应该是

this.elem=document.getElementById(id);
于 2013-10-16T23:28:16.830 回答
0

如果您想在没有 jquery 的情况下执行此操作,那么您需要的代码。您的原始 javascript 中有几个拼写错误。我还更改了是否让所有未悬停的元素立即隐藏。

HTML

<div id="menus">
    <div id="parismenu">
        <a href="#" onmouseover="dropMenu('dropmenu1');">Paris</a>
        <div id="dropmenu1" class="dropmenus">
            <a href="#">apple</a>
        </div>
    </div>
    <div id="disneymenu">
        <a href="#" onmouseover="dropMenu('dropmenu2');">Paris</a>
        <div id="dropmenu2" class="dropmenus">
            <a href="#">apple</a>
        </div>
    </div>
</div>

JAVASCRIPT

var menu = ["dropmenu1", "dropmenu2"];

function dropMenu(x) {
    for (var m in menu) {
        if(menu[m] != x){
            document.getElementById(menu[m]).style.opacity = 0;
            document.getElementById(menu[m]).style.filter = 'alpha(opacity=0)';
        }
    }
    fade.init(x, 1);
}
var fade=function(){
    return{
        init:function(id, flag, target){
            this.elem = document.getElementById(id);
            clearInterval(this.elem.si);
            this.target = target ? target : flag ? 100 : 0;
            this.flag = flag || -1;
            this.alpha = this.elem.style.opacity ? parseFloat(this.elem.style.opacity) * 100 : 0;
            this.elem.si = setInterval(function(){fade.tween()}, 20);
        },
        tween:function(){
            if(this.alpha == this.target){
                clearInterval(this.elem.si);
            }else{
                var value = Math.round(this.alpha + ((this.target - this.alpha) * .05)) + (1 * this.flag);
                this.elem.style.opacity = value / 100;
                this.elem.style.filter = 'alpha(opacity=' + value + ')';
                this.alpha = value
            }
        }
    }
}();

我没有改变你的 CSS。对于一个工作 jsfiddle 检查这个:

http://jsfiddle.net/XfyKZ/

于 2013-10-17T00:40:23.373 回答
0

你为什么不只使用 jquery 推子?我已经清理了你的 javascript 和 html 一点点。而不是使用元素 onMouseover 事件我在加载文档后为该事件添加了一个侦听器到该元素。

<!-- HTML -->
<div id="menus">
    <div id="parismenu">
        <a href="#" class="dropmenu" data-menu-id="#dropmenu1">Paris</a>
        <div id="dropmenu1" class="dropmenus">
            <a href="#">apple</a>
        </div>
    </div>
    <div id="disneymenu">
        <a href="#" class="dropmenu" data-menu-id="#dropmenu2">Disney</a>
        <div id="dropmenu2" class="dropmenus">
            <a href="#">apple</a>
        </div>
    </div>
</div>

然后是 JavaScript:

$(function () {
    $('.dropmenu').on('mouseover', function (event) {
        $($(this).attr('data-menu-id')).fadeIn();
    });
    $('.dropmenu').on('mouseout', function (event) {
        $($(this).attr('data-menu-id')).fadeOut();
    });
});

那么你的 CSS 是不变的。

这是一个显示工作示例的JSFIDDLE 。

于 2013-10-16T23:25:33.063 回答