动态菜单(永远在屏幕的可视区域显示)

公司项目菜单新需求(如题)

当菜单正常显示的时候,如下图



当菜单超出显示区域后,显示在最底层

废话不多说,直接上代码

var str = '<div data-id="'+id+'" class="menu" style="left: '+length+'px ;top: '+top+'px;height:210px">';
         str += '<ul>'
               + '<li class="down_level">新建下级</li>'
               + '<li data-sort="0" class="up_down">上移</li>'
               + '<li data-sort="1" class="up_down">下移</li>'
               + '<li class="edit">编辑</li>'
               + '<li class="delete">删除</li>'
               + '<li class="remove">移动</li>'
               + '<li class="hid">'+hidden+'</li>'
               +'</ul>'
               + '</div>';
         var newtrObj = $(str);
         $(o).closest('td').append(newtrObj);

         var h = $(window).height();    //屏幕的可视区域
         var y = $('.menu').offset().top;    //标签距离顶部高度
         var st = $(window).scrollTop();   //滚动条距顶部高度
         var hB =  h - (y - st) - 30;      
         var hd = h + st - 210;   //计算当菜单置于底部时,此时的top高度
         if (hB > 210) {
            $('.menu').css('top', top+'px');
         } else {
//          $('.menu').css('bottom','0px');
            $('.menu').css('top',hd+'px');
         }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愤怒的小青春

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值