onclick href改变td背景

时间:2011-09-06 06:11:28

标签: javascript css

我对css和javascript都是完整的n00b很抱歉,如果这可能是基本的东西......我正在尝试整理一个显示建筑物概述的表格。 当用户点击任何楼层链接时,一个表格会变为另一个表格(它们都在不同的div中。当用户将鼠标移到它上面时,会显示有关每个单位的更多信息,无论是出租,出售,还是无法使用。 我现在要创建的是一些链接,可以在单击时更改每个单独单元格的背景。因此,例如,当点击show rental units时,所有单元格的背景都会被更改,其中id ='rent'和'both' 在此处查看演示:http://encanto.ximg.co/overviewdemo.html

下面是第一个表的完整源代码(包括css)。我确定它在我试图显示/隐藏td单元格的某个地方也是一个混乱。但是我只能找到告诉td在你点击td而不是href时改变颜色的函数。 正如我所说,我是一个完整的n00b所以请温柔。

    <style type="text/css">
table.overview a {  
border:none;    
display: block; 
}

table.overview td {
    max-height:150px;
    max-width:150px;
    background:#96843c;
}

div.overview td:hover {
    background:#ffffff;
}

div.overview td.white {
    background:#ffffff;
}

div.overview    a {
color: #ffffff; 
text-decoration:none;
text-align:center;
letter-spacing: 1px; 
font-size:16px; 
line-height:32px; 
font-family:"Century Gothic", helvetica, sans-serif;
padding: 2px 5px;
}

div.overview    p   {
color:#96843c;
text-decoration:none;
text-align:center;
letter-spacing: 1px;
font-size:10px;
line-height:10px;
font-family:Georgia, "Times New Roman", Times, serif;
}

div.overview    a:hover {
color: #96843c;
background: #ffffff;
font-family: "Century Gothic";
}



</style>

<script type="text/javascript"><!--

function show_visibility(){
for(var i = 0,e = arguments.length;i < e;i++){
var myDiv = document.getElementById(arguments[i]).style;
myDiv.display = "block";
}
}

function hide_visibility(){
for(var i = 0,e = arguments.length;i < e;i++){
var myDiv = document.getElementById(arguments[i]).style;
myDiv.display = "none";
}
}
</script>

<table summary="" cellpadding="1" cellspacing="1" class="floor">

<tr>

<td>
<a href="#"onClick="show_visibility('floor1');hide_visibility('floor2');hide_visibility('penthouse') ">Ground Floor</a>
</td>

<td>
<a href="#" onClick="show_visibility('rental');show_visibility('both');hide_visibility('sales');hide_visibility('na') ">Show Rental Units</a>
</td>

</tr>

<tr>

<td>
<a href="#" onClick="show_visibility('floor2');hide_visibility('floor1');hide_visibility('penthouse')">1st Floor</a>
</td>

</tr>

<tr>

<td>
<a href="#" onClick="show_visibility('penthouse');hide_visibility('floor1');hide_visibility('floor2')">Penthouse</a></td>
</tr>
</table>


<div id='floor1' class="overview" style="display:none">

<table summary="" cellpadding="1" cellspacing="1" class="overview" width="630">


<tr>
<td colspan="12" height="25" class="white"></td>
</tr>
<tr>
<td colspan="1" rowspan="7" width="25" class="white"><img src="http://encanto.ximg.co/calle10.jpg" /></td>
<td colspan="8" height="25" class="white"><img src="http://encanto.ximg.co/adjacent.jpg" /></td>
<td colspan="1" rowspan="7" width="25" class="white"><img src="http://encanto.ximg.co/calle12.jpg" /></td>
<td colspan="1" rowspan="7" width="25" class="white"></td>
</tr>


<tr>
<td colspan="4" id="sale"><a href="http://www.encantoriviera.com/unit14/"onfocus="this.blur()"> 
14</a>
<p> 
<strong>FOR SALE</strong>
<br /> 
2 Bed/2 Bath 
<br /> 
1131 sq ft./105 sq m.
</p>
</a>
</td>

<td colspan="4" id="na"><a href="http://www.encantoriviera.com/real-estate/vacation-rentals/"onfocus="this.blur()">1</a>
<p>
<strong>NOT AVAILABLE</strong> 
<br /> 
2 Bed/2 Bath
<br /> 
1677 sq ft./156 sq m.
</p>
</a>

</td>
</tr>


<tr>
<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()"> 
13
<p> 
<strong>NOT AVAILABLE</strong>
<br /> 
1 Bed/ 1.5 Bath
<br />
840 sq ft./78 sq m.
</p>
</a>

</td>
<td colspan="4" rowspan="4" width="300" class="white">
</td>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()">
2
<p> 
<strong>NOT AVAILABLE</strong>
<br /> 
2 Bed/ 2 Bath
<br />
872 sq ft./82 sq m.
<br />  
</p>
</a>

</td>
</tr>

<tr>
<td colspan="2" width="150" id="sale"><a href="http://www.encantoriviera.com/unit12/"onfocus="this.blur()"> 
12
<p> 
<strong>FOR SALE</strong>
<br /> 
1 Bed/ 1.5 Bath
<br />
850 sq ft./79 sq m.
<br />  
</p>
</a>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()"> 
3
<p> 
<strong>SOLD</strong>
<br /> 
2 Bed/ 2 Bath
<br />
1130 sq ft./105 sq m.
</p>
</a>

</td>
</tr>


<tr>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()" > 
11
<p> 
<strong>NOT AVAILABLE</strong>
<br /> 
2 Bed/ 2 Bath
<br />
1071 sq ft./101 sq m.
<br />  
</p>
</a>


<td colspan="2" width="150" id="both"><a href="http://www.encantoriviera.com/unit4/"onfocus="this.blur()"> 
4
<p> 
<strong>FOR SALE AND RENT</strong>
<br /> 
2 Bed/ 2 Bath
<br />
1092 sq ft./101 sq m.
</p>
</a>
</td>
</tr>

<tr>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()" >
10
<p> 
<strong>NOT AVAILABLE</strong>
<br /> 
2 Bed/ 2 Bath
<br />
1087 sq ft./101 sq m.
</p>
</a>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()"> 
5
<p> 
<strong>SOLD</strong>
<br /> 
2 Bed/ 2 Bath
<br />
1092 sq ft./101 sq m.
</p>
</a>
</td>
</tr>

<tr>
<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/"onfocus="this.blur()"> 
9
<p> 
<strong>SOLD</strong>
<br /> 
2 Bed/ 2.5 Bath
<br />
1506 sq ft./140 sq m.
</p>
</a>

</td>

<td colspan="2" width="150" id="na"><a href="http://www.encantoriviera.com/unit8/"onfocus="this.blur()"> 
8
<p> 
<strong>FOR SALE AND RENT</strong>
<br /> 
1 Bed/ 1.5 Bath
<br />
915 sq ft./85 sq m.
</p>
</a>
</td>

<td colspan="2" width="150" id="sale"><a href="http://www.encantoriviera.com/unit7/"onfocus="this.blur()"> 
7
<p> 
<strong>FOR SALE</strong>
<br /> 
1 Bed/ 1 Bath
<br />
824 sq ft./75 sq m.
</p>
</a>

</td>

<td colspan="2" width="150" id="sale"><a href="http://www.encantoriviera.com/unit6/"onfocus="this.blur()">
6
<p> 
<strong>FOR SALE AND RENT</strong>
<br /> 
1 Bed/ 1.5 Bath
<br />
869 sq ft./81 sq m.
</p>
</a>

</td>

</tr>
<tr>
<td colspan="12" max-height="25" class="white"><img src="http://encanto.ximg.co/avenida20.jpg" /></td>
</tr>

</table>
</div>

1 个答案:

答案 0 :(得分:0)

您拥有获得预期结果所需的一切。您提供的两种JavaScript函数都有基本逻辑。您只需要告诉JavaScript更改backgroundColor,而不是更改display属性。

我建议使用更具描述性的名称制作两个新函数(例如:highlightCell),并更改for循环内更改的属性。