JS点击显示导航菜单效果,求能切换的。

JavaScript023

JS点击显示导航菜单效果,求能切换的。,第1张

你是不是还有个div的id为hidden2了 但是你这里只有一个div,我已经在加了一个div id为hidden2 看看是不是你要的那种效果。

<a href="javascript:DIVShow('hidden1')">个人产品</a>

<a href="javascript:DIVShow('hidden2')">商用产品</a>

<div class="show" style="display:none" id="hidden1">

<ul class="nav_2">

<div class="jtou" style="position:relativeleft:116pxtop:-11px"></div>

<span style="float:leftcolor:#0085C3font-size:15pxfont-weight:boldheight:55pxline-height:55px">限时特惠 </span>

<li><a href="#">笔记本</a></li>

<li><a href="#">超级本</a></li>

<li><a href="#">台式机</a></li>

<li><a href="#">一体机</a></li>

<li><a href="#">Alienware游戏电脑及配件</a></li>

<li><a href="#">显示器</a></li>

</ul>

</div>

<div class="show" style="display:none" id="hidden2">asfaff</div>

<html>

<head>

<meta http-equiv="Content-Type" content="text/htmlcharset=gb2312">

<title>多选项切换导航菜单</title>

</head>

<style type="text/css">

#dNavBar{

background-color:#ffffff

}

#dNavBar li{

list-style-type:none

float:left

width:84px

height:28px

line-height:28px

font-size:12px

color:#FFFFFF

border:1px solid #ffffff

background:#86C2FF

text-align:center

display:block

cursor:pointer

}

#subMenu{

background:#99cc66

width:500px

border-left:1px solid #ffffff

border-right:1px solid #ffffff

height:29px

line-height:29px

color:#FFFFFF

font-size:12px

padding-left:10px

}

body {

margin: 0px

}

a:link,a:visited {

color: #FFFFFF

text-decoration: none

}

a:hover{

color: #FFFFFF

text-decoration: none

}

</style>

<script language="javascript">

function ShowMenu()

{

var barCTT=document.getElementByIdx_x("dNavBar")

var liArr=barCTT.getElementsByTagName_r("li")

var links=new Array()

links[0]="<a href='#'>当前位置:首页"

links[1]="<a href='#'>项目一</a>| <a href='#'>项目二</a>| <a href='#'>项目三</a>| <a href='#'>项目四</a>"

links[2]="<a href='#'>项目一</a>| <a href='#'>项目二</a>| <a href='#'>项目三</a>"

links[3]="<a href='#'>项目一</a>| <a href='#'>项目二</a>| <a href='#'>项目三</a>| <a href='#'>项目四</a>| <a href='#'>项目五</a>"

links[4]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[5]="<a href='#'>项目一</a>| <a href='#'>项目二</a>| <a href='#'>项目三</a>"

links[6]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[7]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[8]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[9]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[10]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[11]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

links[12]="<a href='#'>项目一</a>| <a href='#'>项目二</a>"

for (i=0i<liArr.lengthi++)

{

liArr[i].onclick=function()

{

selectThis(this,liArr,links)

}

}

}

function selectThis(indexObj,allLi,infoArr)

{

var index=0

for (i=0i<allLi.lengthi++)

{

allLi[i].style.border="1px solid #ffffff"

allLi[i].style.backgroundColor="#86C2FF"

allLi[i].style.height="28px"

if (indexObj==allLi[i])

{

index=i

}

}

indexObj.style.borderBottom="0px solid #666688"

indexObj.style.backgroundColor="#99cc66"

indexObj.style.height="31px"

document.getElementByIdx_x("subMenu").innerHTML=infoArr[index]

}

</script>

<body onLoad="ShowMenu()">

<div id="dNavBar" style="float:nonewidth:560px"><li>首页</li><li>娱乐快报</li><li>音乐天地</li><li>极品FLASH</li>

</div>

<div id="subMenu">站务公告</div>

</body>

</html>

今天研究了一下JS的用setAttribute方法实现一个页面两份样式表的效果,具体方法如下:

第一步:在连接样式表的元素里定义一个id,例如

复制代码

代码如下:

<link

href=”1.css”

rel=”stylesheet”

type=”text/css”

id=”css”>

我定义的id是css。

第二步:写一个js函数,代码如下:

复制代码

代码如下:

<script

type=”text/javascript”>

function

change(a){

var

css=document.getElementById(“css”)

if

(a==1)

css.setAttribute(“href”,”1.css”)

if

(a==2)

css.setAttribute(“href”,”2.css”)

}

</script>

这个函数的code可以放在页面的任何地方。

第三步:为改变页面的样式表的连接添加一个函数的触发事件,代码如下:

复制代码

代码如下:

<a

href=”#”

onClick=”change(1)”>1.css</a>

<a

href=”#”

onClick=”change(2)”>2.css</a>

该效果在IE和FF下均测试通过,相信大家看完后因该非常明了,利用这个方法我们可以让浏览者自己选择需要显示的样式表,比如年老者可以选择一个字体较大的样式表。这里需要注意的两点是:

在这个例子中函数名function后面的名字不能为links或者link,如果为links或者link,样式表将不被改变,具体什么原因我也不大清楚,可能是javascript的保留字符。

另外如果是改变整个页面的样式,你需要在样式表文件里定义body的高度为100%

方法二:

第一步:导入两套css文件

复制代码

代码如下:

<link

rel="stylesheet"

type="text/css"

title="样式A"

href="css/people1.css"

/>

<link

rel="alternate

stylesheet"

type="text/css"

title="样式B"

href="css/people2.css"

/>

第二步:写切换的js函数

复制代码

代码如下:

<script

type="text/javascript">

var

title

=

"样式A"

function

setStyle(){

//只是样式A

和样式B切换

if(title=="样式A"){

title

=

"样式B"

}else{

title

=

"样式A"

}

var

i,links

//用dom方法获取所有link元素

links

=

document.getElementsByTagName("link")

//判断每个link元素中是否含有style字符串

,用来判断此link元素为样式表link

,同时判断此link是否包含title属性

for(i=0

links[i]

i++){

if(links[i].getAttribute("rel").indexOf("style")

!=

-1

&&

links[i].getAttribute("title")){

//把所有link设为disabled

links[i].disabled

=

true

//再来判断title中是否有指定的title字符串

有则把当前的link设为可视

即激活当前的link

if(links[i].getAttribute("title").indexOf(title)

!=

-1){

links[i].disabled

=

false

//alert("ok")

}

}

}

}

</script>

第三步:在html标签中调用切换的js函数

复制代码

代码如下:

<a

href="#"

onclick="setStyle()"

>1</a>

<a

href="#"

onclick="setStyle()">2</a>

<a

href="#"

onclick="setStyle()">3</a>

<a

href="#"

onclick="setStyle()">4</a>

<a

href="#"

onclick="setStyle()">5</a>