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

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

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



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

废话不多说,直接上代码

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');
         }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值