`
jiang_918
  • 浏览: 4538 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

options

    博客分类:
  • web
 
阅读更多
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
  <title> New Document </title>
  <meta name="Generator" content="EditPlus">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <script type="text/javascript">
function Map(linkItems) {  
this.current = undefined;  
this._size = 0;  
if(linkItems === false){ 
this.disableLinking();  
}  

/**
* 获取当前map
* @return 当前对象
*/ 
Map.noop = function() {  
return this;  
};  
/**
* 非法操作
* @return
*/ 
Map.illegal = function() {  
throw new Error("非法操作,Map已经被禁用");  
};  
/**

* @param obj
* @param foreignKeys
* @return
*/ 
Map.from = function(obj, foreignKeys) {  
var map = new Map;  
for(var prop in obj) {  
if(foreignKeys || obj.hasOwnProperty(prop)){ 
map.put(prop, obj[prop]);  
}  
}  
return map;  
};  
/**
* 禁用map
* @return
*/ 
Map.prototype.disableLinking = function() {  
this.link = Map.noop;  
this.unlink = Map.noop;  
this.disableLinking = Map.noop;  
this.next = Map.illegal;  
this.key = Map.illegal;  
this.value = Map.illegal;  
this.clear = Map.illegal;  
return this;  
};  
/**
* 返回hash值 例如:number 123
* @param value key/value
* @return
*/ 
Map.prototype.hash = function(value) {  
return (typeof value) + ' ' + (value instanceof Object ? (value.__hash || (value.__hash = ++arguments.callee.current)) : value.toString());  
};  
/**
* 返回map的长度
* @return
*/ 
Map.prototype.size = function() {  
return this._size; 
};  
 
Map.prototype.hash.current = 0;  
/**
* 通过key获取value
* @param key
* @return
*/ 
Map.prototype.get = function(key) {  
var item = this[this.hash(key)];  
return item === undefined ? undefined : item.value;  
};  
/**
* 向map中添加数据
* @param key 键
* @param value 值
* @return
*/ 
Map.prototype.put = function(key, value) {  
var hash = this.hash(key);  
if(this[hash] === undefined) {  
var item = { key : key, value : value };  
this[hash] = item;  
this.link(item);  
++this._size;  
}else{ 
this[hash].value = value; 
}  
return this;  
};  
/**
* 通过key删除数据
* @param key
* @return
*/ 
Map.prototype.remove = function(key) {  
var hash = this.hash(key);  
var item = this[hash];  
if(item !== undefined) {  
--this._size;  
this.unlink(item);  
delete this[hash];  
}  
return this;  
};  
/**
* 清除map
* @return
*/ 
Map.prototype.clear = function() {  
while(this._size){ 
this.remove(this.key());  
}  
return this;  
};  
/**
* 处理队列
* @param item
* @return
*/ 
Map.prototype.link = function(item) {  
if(this._size == 0) {  
item.prev = item;  
item.next = item;  
this.current = item;  
}else {  
item.prev = this.current.prev;  
item.prev.next = item;  
item.next = this.current;  
this.current.prev = item; 
}  
};  
Map.prototype.unlink = function(item) {  
if(this._size == 0){  
this.current = undefined; 
}else {  
item.prev.next = item.next;  
item.next.prev = item.prev;  
if(item === this.current){ 
this.current = item.next;  
}  
}  
};  
/**
* 获取下一个
* @return
*/ 
Map.prototype.next = function() {  
this.current = this.current.next;  
return this; 
};  
/**
* 获取key
* @return
*/ 
Map.prototype.key = function() {  
return this.current.key;  
};  
/**
* 获取value
* @return
*/ 
Map.prototype.value = function() {  
return this.current.value;  
};    
function a()
{
var map=new Map();
map.put('5',5);
map.put('1',1);



var ops = document.getElementById("sel").options;
for(i=0;i<ops.length;i++)
{
if(map.get(ops.options[i].value) != undefined)
{
//alert(map.get(ops.options[i].value));
ops.options.remove(i);
}
}

}

  </script>
</head>

<body>




<select id="sel" style="width:200px">
<option value=1  alt="abc"> 1 </option>
<option value=2> 2 </option>
<option value=3> 3 </option>
<option value=4> 4 </option>
<option value=5> 5 </option>
<option value=6> 6 </option>
<option value=7> 7 </option>
<option value=8> 8 </option>
<option value=9> 9 </option>

</select>


<input type="button" value="aaaaaa" onclick="a()">
</body>
</html>
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Options_8.34.91.zip for Mac

    《罗技Logi Options for Mac:个性化鼠标操作的利器》 在数字时代,电脑外设的性能和功能已经成为提升工作效率的重要一环。罗技作为知名的外设制造商,为用户提供了一系列高级且可定制化的设备,其中Logi Options...

    X-Frame-Options未配置漏洞修复参考v1.0.docx

    为了防范这种攻击,网站管理员应该在服务器端配置X-Frame-Options头,指示浏览器是否允许页面在frame或iframe中显示。X-Frame-Options头有三种可能的值: 1. **DENY**:不允许任何域加载此页面,包括同一域下的页面...

    罗技鼠标、键盘增强工具Logitech Options 8.36.86

    【罗技Options软件详解】 罗技Options是一款专为罗技(Logitech)用户设计的增强工具,它旨在提升罗技鼠标、键盘以及触摸板的性能和功能,为用户提供更为个性化和高效的操作体验。通过这款软件,你可以根据自己的...

    Mac罗技鼠标管理器Options_8.34.91.zip

    《Mac罗技鼠标管理器Options_8.34.91.zip:提升你的Mac操作体验》 罗技鼠标管理器Options是一款专为Mac用户设计的软件,它旨在增强罗技鼠标与Mac系统的兼容性和功能,提供更为个性化的操作体验。这款软件的版本号...

    X-Frame-Options相关文件

    描述中提到的"X-Frame-Options头缺失 in a frame because it set 'X-Frame-Options' to 'deny'",意味着在某个特定的场景下,一个网页没有设置X-Frame-Options头,或者设置了值为'deny'的X-Frame-Options头,这表明...

    WordPress数据库清理插件Clean Options

    其实不然,还有或多或少的残留文件还悄悄地隐藏在你Wordpress数据库中的wp_options表中,如此长此发展下去,我们的数据库会在不知不觉中,变的越来越越庞大。 而且,WordPress管理后台的首页或其它页面,还会自动...

    解决axios会发送两次请求,有个OPTIONS请求的问题

    在使用Vue框架和axios库进行前后端交互时,开发者可能会遇到axios请求被发送两次的情况,其中包含一个OPTIONS请求。本文详细介绍了这个问题的原因以及解决方案。 首先,问题出现的原因与axios的默认请求头设置有关...

    OptionsMenu选项菜单使用Demo

    OptionsMenu是Android系统中的一种用户界面元素,用于在屏幕顶部或底部显示一组操作选项,通常在用户需要执行特定操作时出现,比如在应用的主界面点击菜单按钮。在Android开发中,OptionsMenu是一个重要的交互设计,...

    X-Frame-Options头缺失漏洞修复-esapi.zip

    X-Frame-Options头允许服务器告诉浏览器是否可以在 iframe 或 object 元素中加载页面。如果不设置此头部,攻击者就有可能利用这个漏洞将目标网站嵌入到他们的恶意网页中,从而实现点击劫持。通常,X-Frame-Options头...

    Logitech Options 6.60.570.exe

    Logitech Options 6.60.570.exe Logitech Options旧版本

    Options_8.36.76.zip

    标题“Options_8.36.76.zip”暗示了这是一个软件更新或配置包,针对的是罗技(Logitech)的一款产品,版本号为8.36.76。描述中提到“MAC os 罗技键盘k780 App”,这表明这个压缩包包含了适用于Mac OS操作系统的罗技K...

    gin跨域支持options请求

    gin跨域支持options请求。亲测可用啊,这个是一个大佬发给我的

    Options_8.54.161.exe

    Logitech Options

    DHCP 协议 RFC2131 RFC2132 options60 部分

    "options 60协议规范.pdf"可能包含了对options60的深入解析和使用示例;而"rfc2132.txt"则是RFC2132的文本版本,详细列出了所有可用的DHCP选项及其用途。 学习和理解DHCP协议,尤其是RFC2131和RFC2132,对于网络...

    Options_8.36.86.exe

    Logitech Options

    罗技 新版options+ 驱动

    罗技 新版options+ 驱动

    vue3中Options API(学习)代码

    Vue3 是 Vue.js 框架的最新版本,它引入了许多新特性和改进,其中一项重要的变化就是对 Options API 的支持。尽管 Vue3 强调了Composition API 的使用,但为了兼容旧版项目和便于开发者过渡,Options API 仍然被保留...

    Laravel开发-laravel-options

    在Laravel框架中,"options"通常指的是应用配置选项,它是Laravel系统中一个关键的组成部分,用于存储和管理应用程序的设置。`laravel-options`可能是某个特定的扩展包或库,它提供了一个简单的方式来处理键值对形式...

    vlc中文options参数使用手册

    vls参数,含600多条options命令,表格经过精心整理且分类,附带每条参数的中文说明及格式

    Laravel开发-options

    **Laravel 开发 - Options** Laravel 是一个优雅且强大的 PHP 框架,它为开发者提供了丰富的工具和功能,简化了Web应用的构建过程。在 Laravel 的世界里,"options" 可能指的是用于存储和管理应用配置的组件或者是...

Global site tag (gtag.js) - Google Analytics