网络营销就是新竞争力
当前位置:新竞争力首页 > 公司博客首页 > 邓鹏的博客
网站导航优化---JS弹出菜单

       搜索引擎抓取页面,实际就是抓取网页的HTML源代码,在HTML源代码中,用嵌入JS文件的方式实现网站导航一般以下面这种形式出现:
 <table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="300">&nbsp;</td>
<td width="71%" align="center">
<script language=javascript>
createMainLayer();
</script>
</td>
</tr>
</table>
     我们会发现在上述代码中没有导航栏的HTML代码,页面中呈现出来的导航栏全部是由javascript的createMainLayer()函数生成的,而这个函数就是在嵌入的javascript文件中定义的。我们看不到导航栏的HTML代码,搜索引擎同样也看不到这些代码,而搜索引擎并不能识别javascript函数,所以写在javascript中的链接就失去了被抓取的机会。网站更深层次的内容将不会被抓取。
       新竞争力网络营销管理顾问(www.jingzhengli.cn)的改进方法是使用少量js和css方式实现网站导航。这种导航菜单实现的要点不外乎是当鼠标移到目标上时, 显示出隐藏的标签. 要隐藏的标签使用 display:none; 属性进行隐藏. 触发显示隐藏标签主要使用 :hover 属性, 并用 display:block; 显示隐藏的标签。
       但由于浏览器对 CSS 的支持并非一致.对于 Opera 或者 Firefox, 我们可以编写出纯 CSS 菜单, 他们支持任何标签的 :hover 属性.而对于 IE 浏览器, :hover 只对 a 标签起作用, 但我们可以使用脚本的 onmouseover, onmouseout 模拟出其他标签的 :hover 属性.因此编写适用于 IE 的 CSS 弹出菜单必须使用到少许的JS脚本。下面是一个简单的JS+CSS导航菜单的实例,供大家参考:
Css.css文件:
body{ margin:0px auto; width:768px; /* 定义页面居中显示,*/}
    *{text-decoration:none!important; /* 定义所有链接不显示下划线 */}
    /* ------------------- start 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    .mainnav{background-color:#fff!important; /* 定义主菜单域背景色 */} 
    .mainnav .level{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    }
    .mainnav .level:hover { /* 当鼠标划过一级菜单时 */
        background-color:#6633FF; /* 背景色 */
        color:#FFFFFF; /* 文字颜色 */
    }
    .mainnav .level_{display:none; /* 默认隐藏二级类别 */}
    
    .mainnav .level:hover .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        left:124px; /* 相对于一级类别显示的位置 */
        width:120px; /* 宽度 */
        height:auto; /* 高度 */
        top:0px; /* 相对于一级类别所在位置的顶端 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .mainnav .level:hover .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .mainnav .level:hover .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .mainnav .level:hover .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
    /* ------------------- end 针对 Opera, Firefox 的 CSS 弹出菜单 -------------------*/
    
    /* ------------------- start 针对 IE 的 CSS 弹出菜单 -------------------*/
    .levelIe{  /* 定义一级类别属性 */
        width:120px; /* 宽度 */
        height:17; /* 高度 */
        position:relative; /* 显示位置为相对位置 */
        display:block; /* 以块模式显示 */
        background-color:#D8D8D8; /* 背景色 */
        padding:0px 2px; /* 文字内补丁间隔 */
        margin:0px 0px 1px 0px; /* 菜单外补丁间隔 */
    }
    .levelIe .level_ { /* 鼠标划过时触发显示二级类别 */
        display:block; /* 以块显示 */
        left:124px; /* 相对于一级类别显示的位置 */
        width:120px; /* 宽度 */
        height:auto; /* 高度 */
        top:0px; /* 相对于一级类别所在位置的顶端 */
        background-color:#EFEFEF; /* 定义背景色 */
        position:absolute; /* 位置为绝对位置 */
    }
    .levelIe .level_ .level_title {
        /* 定义二级类别标题样式 */
        font-weight:bold; /* 字体加粗 */
        background-color:#A7ADFE; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ a:hover {
        /* 定义二级类别链接显示样式 */
        background-color:#F83658; /* 背景色 */
        color:white; /* 文字颜色 */
    }
    .levelIe .level_ * { 
        /* 定义所有二级类别通用属性 */
        display:block; /* 以块显示 */
        color:black; /* 文字颜色 */
        padding:0px 2px; /* 内补丁间隔 */
    }
/* ------------------- end 针对 IE 的 CSS 弹出菜单 -------------------*/
Showmemu.js文件:
if (navigator.appName=="Microsoft Internet Explorer") {
    function fmainnav() {
        var getItem = document.getElementById("mainnav").getElementsByTagName("div");
        for (var i=0; i<getItem.length; i++) {
            getItem[i].onmouseover=function() { 
                if(    this.className=="level"){
                    this.className="levelIe";
                }
            }
            getItem[i].onmouseout=function() { 
                if(    this.className=="levelIe"){
                    this.className="level";
                }
            }
        }
    }
    window.onload=fmainnav;
}
</script>

HTML页面文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
" http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>网站导航菜单实例</title>
<link href="/Blog/css.css" rel="stylesheet" type="text/css" />
<script language="javascript" type="text/javascript" src="/Blog/showmemu.js"></script>
</head>
<body>
<p/><p/><p/><p/><p/>
<div class="mainnav" id="mainnav">
    <div class="level">
        <div class="levelTitle">一级栏目1</div>
        <div class="level_">
            <div class="level_title"> <a href="">二级栏目1</a> </div>
            <a href="">二级栏目2</a>
            <a href="">二级栏目3</a>
            <a href="">二级栏目4</a>
            </div>
    </div>
    <div class="level">
        <div class="levelTitle">一级栏目2</div>
        </div>
    <div class="level">
        <div class="levelTitle">一级栏目3</div>
        <div class="level_">
            <div class="level_title"> <a href="">二级栏目1</a> </div>
            <a href="">二级栏目 2</a>
            <a href="">二级栏目 3</a>
            <a href="">二级栏目 4</a>
            <a href="">二级栏目 5</a>
        </div>
    </div>
    <div class="level">
        <div class="levelTitle">一级栏目4</div>
        </div>
    <div class="level">
        <div class="levelTitle">一级栏目5</div>
       </div>
</div>
</body>
</html>

通过例子中的代码我们可以看到,所有分类的链接都在HMTL代码中呈现出来,这样搜索引擎就能方便的抓取到更深层次的内容,同时也能很好的照顾到用户体验。

发表评论:

    昵称:
    密码:
    标题:
“新竞争力”是深圳市竞争力科技有限公司的注册商标
深圳市竞争力科技有限公司 版权所有
电话:86-755-26502263  Email:info@jingzhengli.cn