js 浮动层菜单收藏


Posted in Javascript onJanuary 16, 2009

使用说明
即仅需把附件中的 JS 文件和 CSS 文件引用到网页里,如:

<script type="text/javascript" src="DivMenu.js"></script> 
<link href="DivMenu.css" rel="stylesheet" type="text/css" />

在线演示 http://img.3water.com/online/DivMenu/DivMenu.htm
下载源码打包 http://img.3water.com/online/DivMenu/DivMenu.zip
其中 DivMenu.js 是经 Javascript compressor 压缩的精简版本,供生成实际使用。DivMenu_develop.js 是带详细注释的开发版,供学习研究。使用时可以参考 DivMenu.css 文件中的注释,自行修改样式定义。
JavaScript 程序已经实现免打扰(unobtrusive),即引用此 JS 文件的 HTML 文件无需任何其它调整。但还未实现完全匿名(anonymous),意思是此程序仍然创建了全局变量和若干网页节点,已经尽量做到少增加全局变量和节点,但使用时仍请注意变量命名冲突。此程序仅增加一个全局变量“DivMenu”,增加的网页节点比较多,对应替换掉的每个 SELECT 节点增加两个节点,名字分别是 SELECT 节点的 name 值加“_a”后缀和“_div”后缀,例如原有某 SELECT 节点的名字是“menu”,则新增的两个节点名字是“menu_a”和“menu_div”。
功能说明
多选菜单不转换,多选菜单中的提示文字只能用 disabled="disabled" 来实现了。 若要选择多个,请住 Ctrl 键再选择 多选1 多选2 多选3 多选4 多选5 放一个多选菜单,用来演示多选菜单不会被替换,以及在 IE6 中浮动层可以正常显示在其它 SELECT 以上了。
以上是个实用的范例,几组经典的 SELECT 选择菜单,第一个是复杂带分组的,提示文字用 disabled="disabled" 的第一个 option 实现,后一个是简单的,提示文字用的是没有 value 属性的那个 option。实践发现 FF 可以正常处理 disabled="disabled" 或者仅 disabled 的 option,让它可以不可选的状态,而 IE 则无视任何disabled="disabled" 和 disabled,所以估计通常 IE 里的菜单想用提示文字都会用没有 value 属性或者 value=""的那个 option。可以看它的源码就是原来的 SELECT,不需要任何改动。
基本思路是把文档中原有的 SELECT 菜单转换成隐藏型的 INPUT 表单项,用 A 元素来做菜单的提示文字条和选项条,用 DIV 层做菜单,各个选项也用 A 元素来替代,点击时把值赋给隐藏型的 INPUT 表单项。
主要功能或限制包括:
所有使用习惯遵循传统的 SELECT 菜单。
只有单选的 SELECT 菜单会被替换,多选菜单维持不变,因为通常多选菜单也不用浮动层菜单来替代。
支持各种 SELECT 元素的特性,如把 disabled 的或者没有 value 的 option 作为提示文字条;用 optgroup 分组的选项也会在新菜单中分组。并且专门针对 IE 6 中 SELECT 挡住 DIV 层的 BUG 进行了修正。
支持默认选中项。
几乎支持普通菜单的所有功能,但是不支持额外的交互功能,如 JavaScript 实时创建的 Option 选项、联动选项等,比如选一个城市区县会相应变化这类的功能是不支持的。
全部样式都用 CSS 定义,字号使用相对大小,无需改动即可适应多数网页。
菜单位置和尺寸均设置成灵活的,可适应任意的网页排版和布局。做的时候考虑的是要能在替代的 A 元素中显示时,放得下最宽的选项文字,因而没有直接取原有 SELECT 框的宽度。因此菜单尺寸可能比原有的 SELECT 宽,使用时请注意。
欢迎试用,并提出意见建议,共用探讨改进。
Javascript 相关文章推荐
js toFixed()方法的重写实现精度的统一
Mar 06 Javascript
使用js dom和jquery分别实现简单增删改
Sep 11 Javascript
js实现屏幕自适应局部代码分享
Jan 30 Javascript
基于Jquery代码实现支持PC端手机端幻灯片代码
Nov 17 Javascript
JS实现的仿淘宝交易倒计时效果
Nov 27 Javascript
实例讲解使用原生JavaScript处理AJAX请求的方法
May 10 Javascript
将鼠标焦点定位到文本框最后(代码分享)
Jan 11 Javascript
angular和BootStrap3实现购物车功能
Jan 25 Javascript
全选复选框JavaScript编写小结(附代码)
Aug 16 Javascript
JS实现的简单分页功能示例
Aug 23 Javascript
vue 的点击事件获取当前点击的元素方法
Sep 15 Javascript
axios取消请求的实践记录分享
Sep 26 Javascript
jquery中常用的SET和GET
Jan 13 #Javascript
JavaScript 私有成员分析
Jan 13 #Javascript
js利用Array.splice实现Array的insert/remove
Jan 13 #Javascript
JavaScript delete操作符应用实例
Jan 13 #Javascript
在网页里看flash的trace数据的js类
Jan 10 #Javascript
捕获关闭窗口的脚本
Jan 10 #Javascript
javascript 自动转到命名锚记
Jan 10 #Javascript
You might like
php对mongodb的扩展(初出茅庐)
2012/11/11 PHP
解析smarty模板中类似for的功能实现
2013/06/18 PHP
php获取网页里所有图片并存入数组的方法
2015/04/06 PHP
PHP可变变量学习小结
2015/11/29 PHP
php微信开发自定义菜单
2016/08/27 PHP
php使用curl实现简单模拟提交表单功能
2017/05/15 PHP
laravel数据库查询结果自动转数组修改实例
2021/02/27 PHP
利用404错误页面实现UrlRewrite的实现代码
2008/08/20 Javascript
jQuery学习2 选择器的使用说明
2010/02/07 Javascript
Javascript中定义方法的另类写法(批量定义js对象的方法)
2011/02/25 Javascript
JS实现拖动示例代码
2013/11/01 Javascript
JS判断移动端访问设备并加载对应CSS样式
2014/06/13 Javascript
JavaScript实现简单的拖动效果
2016/07/02 Javascript
AngularJS中一般函数参数传递用法分析
2016/11/22 Javascript
js实现移动端编辑添加地址【模仿京东】
2017/04/28 Javascript
关于在vue-cli中使用微信自动登录和分享的实例
2017/06/22 Javascript
js实现百度登录窗口拖拽效果
2020/03/19 Javascript
[04:50]DOTA2亚洲邀请赛小组赛第四日 TOP10精彩集锦
2015/02/02 DOTA
[01:11:35]Liquid vs LGD 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
使用httplib模块来制作Python下HTTP客户端的方法
2015/06/19 Python
实例讲解Python的函数闭包使用中应注意的问题
2016/06/20 Python
深入浅析Python的类
2018/06/22 Python
详解Appium+Python之生成html测试报告
2019/01/04 Python
Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例
2019/01/23 Python
pygame库实现移动底座弹球小游戏
2020/04/14 Python
Python网络爬虫信息提取mooc代码实例
2020/03/06 Python
python开发一个解析protobuf文件的简单编译器
2020/11/17 Python
基于Django集成CAS实现流程详解
2020/11/28 Python
Android本地应用打开方法——通过html5写连接
2016/03/11 HTML / CSS
Reformation官网:美国女装品牌
2018/09/14 全球购物
劳力士官方珠宝商:J.R. Dunn Jewelers
2018/09/29 全球购物
《李时珍夜宿古寺》教学反思
2014/04/09 职场文书
2016思想纪律作风整顿心得体会
2016/01/23 职场文书
小学英语课教学反思
2016/02/15 职场文书
Mysql 文件配置解析介绍
2022/05/06 MySQL
mysql数据库隔离级别详解
2022/06/16 MySQL