<script type="text/javascript" src="js/jquery-1.5.1.min.js"></script>
<script type="text/javascript">
$(function(){
var settings = [
{
text : "JavaScript框架" ,
items : [
{
text : "JQuery" ,
items : [
{
text : "UI" ,
items : []
} ,
{
text : "Mobile" ,
items : []
}
]
} ,
{
text : "ExtJS" ,
items : []
} ,
{
text : "Dojo" ,
items : [
{
text : "IBM" ,
items : [
{
text : "Web Application Server X" ,
items : []
} ,
{
text : "TAM" ,
items : []
}
]
} ,
{
text : "Oracle-Sun" ,
items : []
}
]
}
]
} ,
{
text : "J2ee框架" ,
items : []
}
] ;
Menu.load(settings)
}) ;
var Menu = function(){
function _getDomId(){
var myString = [
"0","1","2","3","4","5","6","7","8","9","a","b",
"c","d","e","f","g","h","i","j","k","l","m","n",
"o","p","q","r","s","t","u","v","w","x","y","z","_"
] ;
var domId = "" ;
for(var i=0;i<8;i++){
var index = parseInt(Math.random() * myString.length) ;
domId += myString[index] ;
}
return domId ;
}
function _render(items,dom){
var _ul_ = $("<ul></ul>")
.attr("id",_getDomId())
.addClass("menu")
.appendTo("body")
.css(
{
top : dom.offset().top + 5 + "px" ,
left : dom.offset().left + dom.width() - 4 + "px"
}
) ;
dom.attr("ui",_ul_.attr("id")) ;
for(var j=0;j<items.length;j++){
var item = items[j] ;
var _li_ = $("<li></li>")
.appendTo(_ul_)
.mouseover(function(){
$(this).addClass("active") ;
var s = $(this).attr("ui") ;
$(document.getElementById(s)).fadeIn("normal") ;
})
.mouseout(function(){
$(this).removeClass("active") ;
var s = $(this).attr("ui") ;
$(document.getElementById(s)).fadeOut("fast") ;
}) ;
var _a_ = $("<a href='#'></a>")
.html(item.text)
.appendTo(_li_) ;
if(item.items.length){
_a_.addClass("more") ;
_render(item.items,_li_) ;
}
}
} ;
function _init(jq){
jq.show("slow") ;
} ;
function load(settings){
var _ul = $("<ul></ul>")
.addClass("menu")
.appendTo("body") ;
for(var i=0;i<settings.length;i++){
var data = settings[i] ;
var text = data.text ;
var items = data.items ;
var _li = $("<li></li>")
.appendTo(_ul)
.mouseover(function(){
$(this).addClass("active") ;
var s = $(this).attr("ui") ;
$(document.getElementById(s)).fadeIn("normal") ;
})
.mouseout(function(){
$(this).removeClass("active") ;
var s = $(this).attr("ui") ;
// $(document.getElementById(s)).fadeOut("fast") ;
}) ;
var _a = $("<a href='#'></a>")
.html(text)
.appendTo(_li) ;
if(items.length){
_a.addClass("more") ;
_render(items,_li)
}
}
_init(_ul) ;
} ;
return {
load : load
} ;
}() ;
</script>
详细解决方案
右键小菜单练习题-JavaScript
热度:219 发布时间:2012-10-14 14:55:07.0
相关解决方案
- javascript ie6兼容的有关问题
- javascript window open在ie中设立不起作用,求解决
- 不走"<script type='text/javascript'>"标签咋回事
- <script type="javascript/text">的有关问题
- 用servlet+jsp+javascript+jdbc做个简单的办公自动化系统流程,该如何解决
- 怎么打开 javascript:SetData(2010,5,10)
- javaScript = == ===区别,该怎么解决
- javascript 怎么验证name=xx.xx的radio表单
- javascript,该怎么处理
- javascript,该如何处理
- javascript 选中文字 但是保存样式 标签
- 新人求问,J2EE方向,html,css,javascript,vml要学到什么程度?解决思路
- javascript 请求servlet兑现将函数中定义的变量作为参数
- javascript 不懂,该如何处理
- javascript 不懂解决方法
- JavaScript 大局函数求实例,高分求
- javaScript 里面 如何知道Object 对象的长度
- javascript 中文本框中数字如何比较
- javascript IE通过,火狐,google浏览器不过解决思路
- Chrome Javascript Click 事件,该如何解决
- javascript 绑定服务器控件 事件,该如何解决
- javascript 经过加密压缩 怎么解压缩
- JavaScript 怎么获取Table中的某个<span> 的值
- javascript 正则表达式 请用小写字母和数目字,首字母必须为字母,长度5-15
- JavaScript 请问一个思路有关问题,当按下鼠标左键,在屏幕上滑动时,会触发什么事件
- javascript 正则Replace,该怎么处理
- javascript 可以实现登录按钮的功能吗?解决办法
- JavaScript 图片预览效果
- JavaScript 哈希表赋值的有关问题
- JavaScript 除法,希望得到整数解决思路