用Javascript写的一个映射表类
2004-05-07 13:27
507 查看
该类可以通过关键字(key)查找相对应的值(value),关键字的类型可以是String、Number、Boolean类型,值的类型不限,代码如下:
<script>
function struct(key, value){
this.key = key;
this.value = value;
}
function setAt(key, value){
for (var i = 0; i < this.map.length; i++)
{
if ( this.map[i].key === key )
{
this.map[i].value = value;
return;
}
}
this.map[this.map.length] = new struct(key, value);
}
function lookUp(key)
{
for (var i = 0; i < this.map.length; i++)
{
if ( this.map[i].key === key )
{
return this.map[i].value;
}
}
return null;
}
function removeKey(key)
{
var v;
for (var i = 0; i < this.map.length; i++)
{
v = this.map.pop();
if ( v.key === key )
continue;
this.map.unshift(v);
}
}
function getCount(){
return this.map.length;
}
function isEmpty(){
return this.map.length <= 0;
}
function classMap() {
this.map = new Array();
this.lookUp = lookUp;
this.setAt = setAt;
this.removeKey = removeKey;
this.getCount = getCount;
this.isEmpty = isEmpty;
}
window.onload = function(){
var map = new classMap();
alert("is the map empty? " + map.isEmpty());
// string to array
map.setAt("sw1", new Array("sw1_1"));
map.setAt("sw2", new Array("sw2_1", "sw2_2"));
map.setAt("sw3", new Array("sw3_1", "sw3_2", "sw3_3"));
alert(map.lookUp("sw5")); // null
alert(map.lookUp("sw2")); // "sw2_1, sw2_2"
alert(map.getCount()); // 3
// number to string
map.setAt(1, "sw1");
map.setAt(2, "sw2");
alert(map.lookUp(2)); // "sw2"
map.setAt(2, new Array("sw2_1", "sw2_2"));
alert(map.lookUp(2)); // "sw2_1, sw2_2"
alert(map.getCount()); // 5
// string to number
map.setAt("1", 1);
map.setAt("2", 2);
alert(map.lookUp("1")); // 1
alert(map.lookUp(1)); // "sw1"
map.setAt("sw3", 33);
alert(map.lookUp("sw3")); // 33
alert(map.getCount()); // 7
// number to number
map.setAt(1, 11);
map.setAt(2, 22);
alert(map.lookUp(1)); // 11
alert(map.getCount()); // 7
map.removeKey(1);
alert(map.lookUp(1)); // null
alert(map.getCount()); // 6
// boolean to array
map.setAt(false, new Array("false", "true"));
alert(map.lookUp(false));
alert(map.getCount()); // 7
}
</script>
<script>
function struct(key, value){
this.key = key;
this.value = value;
}
function setAt(key, value){
for (var i = 0; i < this.map.length; i++)
{
if ( this.map[i].key === key )
{
this.map[i].value = value;
return;
}
}
this.map[this.map.length] = new struct(key, value);
}
function lookUp(key)
{
for (var i = 0; i < this.map.length; i++)
{
if ( this.map[i].key === key )
{
return this.map[i].value;
}
}
return null;
}
function removeKey(key)
{
var v;
for (var i = 0; i < this.map.length; i++)
{
v = this.map.pop();
if ( v.key === key )
continue;
this.map.unshift(v);
}
}
function getCount(){
return this.map.length;
}
function isEmpty(){
return this.map.length <= 0;
}
function classMap() {
this.map = new Array();
this.lookUp = lookUp;
this.setAt = setAt;
this.removeKey = removeKey;
this.getCount = getCount;
this.isEmpty = isEmpty;
}
window.onload = function(){
var map = new classMap();
alert("is the map empty? " + map.isEmpty());
// string to array
map.setAt("sw1", new Array("sw1_1"));
map.setAt("sw2", new Array("sw2_1", "sw2_2"));
map.setAt("sw3", new Array("sw3_1", "sw3_2", "sw3_3"));
alert(map.lookUp("sw5")); // null
alert(map.lookUp("sw2")); // "sw2_1, sw2_2"
alert(map.getCount()); // 3
// number to string
map.setAt(1, "sw1");
map.setAt(2, "sw2");
alert(map.lookUp(2)); // "sw2"
map.setAt(2, new Array("sw2_1", "sw2_2"));
alert(map.lookUp(2)); // "sw2_1, sw2_2"
alert(map.getCount()); // 5
// string to number
map.setAt("1", 1);
map.setAt("2", 2);
alert(map.lookUp("1")); // 1
alert(map.lookUp(1)); // "sw1"
map.setAt("sw3", 33);
alert(map.lookUp("sw3")); // 33
alert(map.getCount()); // 7
// number to number
map.setAt(1, 11);
map.setAt(2, 22);
alert(map.lookUp(1)); // 11
alert(map.getCount()); // 7
map.removeKey(1);
alert(map.lookUp(1)); // null
alert(map.getCount()); // 6
// boolean to array
map.setAt(false, new Array("false", "true"));
alert(map.lookUp(false));
alert(map.getCount()); // 7
}
</script>
相关文章推荐
- 用Javascript写的一个映射表类
- 用Javascript写的一个映射表(MAP)类--续
- 用Javascript写的一个映射表类
- 用Javascript写的一个映射表类
- meizz(梅花雨)用javascript写的一个日期输入控件!
- Tracker 是一个运行于浏览器书签栏的 JavaScript 嗅探工具,她将被启动于其他网页之后,为了协助您了解目标网页中 JavaScript 的运行情况
- 一个简单的JavaScript表单验证框架
- 一个简单的例子:javascript实现日期的比较(3)
- 为 Javascript 数组添加一个 inArray 方法
- 一个加密JavaScript的开源工具PACKER2.0.2
- 运用canvas技术画一个由内向外渐变的实心圆(javascript)
- 每天一个JavaScript实例-使用缓存计算(memoization)来提高应用程序性能
- 【JAVASCRIPT】React学习-如何构建一个组件
- javascript高级程序设计:一个ajax的插件
- 一个简单的javascript图片放大效果代码
- javascript --- 一个菜单效果代码
- 一个WebSocket客户端的JavaScript例子
- javascript笔记:自己写一个jqgrid框架(一)
- 不知道有没有必要写一个Javascript的算法库……
- 一个查看ASP的JavaScript程序