複製代碼代碼如下:
<tbody >
<tr >
<td >1</td>
<td>樓盤開業<br>折扣大</td>
<td>2011-11-11</td>
<td>簡訊通知</td>
</tr>
<tr >
<td>2</td>
<td>樓盤開業<br>折扣大</td>
<td>2011-11-11</td>
<td>簡訊通知</td>
</tr>
</tbody>
</table>
</div>
</div>
<div id="right" >
<table id="table1">
<caption>詳細資料列表</caption>
<thead>
<tr>
<td> <input type="checkbox" name="checkbox" id="btn"/>全選</td>
<td>簡訊</td>
<td>上傳時間</td>
<td>備註</td>
</tr>
</thead>
<tbody id="selectable">
<tr id="box1" >
<td id="45"> <input type="checkbox" name="box1" />1</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box2" ondragstart="test2()">
<td> <input type="checkbox" name="box2" />
2</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box3" ondragstart="test2()">
<td> <input type="checkbox" name="box3" />
3</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box4">
<td> <input type="checkbox" name="box4" />
4</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box5">
<td> <input type="checkbox" name="box5"/>
5</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box6" onclick="clickDrop()" >
<td> <input type="checkbox" name="box6" />
6</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
<tr id="box7">
<td> <input type="checkbox" name="box7" />
7</td>
<td>開會發現<br>有錯</td>
<td>2011-01-30</td>
<td>五</td>
</tr>
</tbody>
</table>
<input type="button" value="test" onclick="test2();"/>
<script type="text/javascript">
var map = new HashMap();
$(function(){
$("#table1 tr ").click(function(e){
var trId=this.id;
$("input[type='checkbox']").each(function(){//遍歷ID
if(this.name==trId){
if(this.checked==true){
$(this).attr("checked",false);
map.remove(this.name);
var dd=document.getElementById(trId);
dd.style.backgroundColor= "white";
}else{
$(this).attr("checked",true);
map.put(this.name,trId);
var dd=document.getElementById(trId);
dd.style.backgroundColor= " #FECA40";
}
}
});
});
});
</script>
複製代碼代碼如下:
function HashMap()
{
/** Map 大小**/
var size = 0;
/** 物件**/
var entry = new Object();
/** 存**/
this.put = function (key , value)
{
if(!this.containsKey(key))
{
size ++ ;
}
entry[key] = 值;
}
/** 取**/
this.get = function (key)
{
if( this.containsKey(key) )
{
return entry[key];
}
else
{
return null;
}
}
/** 刪除**/
this.remove = function ( key )
{
if( delete entry[key] )
{
size --;
}
}
/** 是否包含Key **/
this.containsKey = function ( key )
{
return (key in entry);
}
/** 是否包含Value **/
this.containsValue = function ( value )
{
for(var prop in entry)
{
if(entry[prop] == value)
{
return true;
}
}
return false;
}
/** 所有Value **/
this.values = function ()
{
var values = new Array(size);
for(var prop in entry)
{
values.push(entry[prop]);
}
return values;
}
/** 所有Key **/
this.keys = function ()
{
var keys = new Array(size);
for(var prop in entry)
{
keys.push(prop);
}
return keys;
}
/** Map Size **/
this.size = function ()
{
return size;
}
}
// var map = new HashMap();
/*
map.put("A","1");
map.put("B","2");
map.put("A","5");
map.put("C","3");
map.put("A","4");
*/
/*
alert(map.containsKey("XX"));
alert(map.size());
alert(map.get("A"));
alert(map.get("XX"));
map.remove("A");
alert(map.size());
alert(map.get("A"));
*/
/** 同時也可以把物件當作Key **/
/*
var arrayKey = new Array("1","2","3","4");
var arrayValue = new Array("A","B","C","D");
map.put(arrayKey,arrayValue);
var value = map.get(arrayKey);
for(var i = 0 ; i < value.length ; i++)
{
//alert(value[i]);
}
*/
/** 把物件做為Key時,自動呼叫了該物件的toString() 方法其實最後還是以String物件為Key**/
/** 如果是自訂物件那自己就得重寫toString() 方法否則. 就是下面的結果**/
// function MyObject(name)
// {
// this.name = name;
// }
/**
function MyObject(name)
{
this.name = name;
this.toString = function ()
{
return this.name;
}
}
**/
// var object1 = new MyObject("小張");
// var object2 = new MyObject("小名");
//
// map.put(object1,"小張");
// map.put(object2,"小名");
// alert(map.get(object1));
// alert(map.get(object2));
// alert(map.size());
//
/** 運行結果小名小名size = 1 **/
/** 如果改成複寫toString()方法的物件, 效果就完全不一樣了**/