主頁 > 知識(shí)庫 > html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)

html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)

熱門標(biāo)簽:長(zhǎng)春極信防封電銷卡公司 電話機(jī)器人批發(fā) 智能電銷機(jī)器人廣告語 貴陽ai外呼系統(tǒng) 電銷外呼線路改不外呼線路 愛巢地圖標(biāo)注 crm外呼系統(tǒng)好不好 重慶人工智能電銷機(jī)器人報(bào)價(jià) 強(qiáng)訊外呼系統(tǒng)

css樣式

html,body{
	width: 100%;
	height: 100%;
	margin: 0;padding: 0;
}

/*導(dǎo)航圖標(biāo)*/
.NMH-g-navicon{
	position: fixed;
	top: 40%;
	right: 020px;
	width: 100px;
	height: 100px;
}
.NMH-g-navicon.Jnmh-onleft{
	right: auto;
	left: 020px;
}
/*導(dǎo)航圖標(biāo)logo按鈕*/
.NMH-g-navicon .Jnmh-btnlogo{
	position: absolute;
	display: block;
	width: 100px;
	height: 100px;
	top: 50%;
	right: 0;
	margin-top: -50px;
	border: 0;
	background: url(img/icon_128.png) no-repeat center center;
    background-size: 95% 95%;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: rgba(0, 0, 0, 0.12) 0px 6px 10px 0px;
	outline: none;
	border-radius: 50%;
	z-index: 1;
}
.NMH-g-navicon .Jnmh-btnlogohover{
	position: absolute;
	display: block;
	width: 100px;
	height: 100px;
	top: 50%;
	right: 0;
	margin: 0;padding: 0;
	margin-top: -50px;
	border: 0;
	overflow: hidden;
	/*background-color: red;*/
}

/*導(dǎo)航圖標(biāo)logo按鈕-鼠標(biāo)經(jīng)過*/
.NMH-g-navicon.Jnmh-open .Jnmh-btnlogohover{
	margin-top: -150px;	
	width: 200px;
	height: 300px;
	border-radius: 150px 0 0 150px;
}
.NMH-g-navicon.Jnmh-onleft .Jnmh-btnlogohover{
	left: 0;
	right: auto;
	border-radius: 0 150px 150px 0;
}
/*導(dǎo)航圖標(biāo)菜單子容器*/
.NMH-g-navicon .Jnmh-m-submenu{
	position: absolute;
	background-color: transparent;
	list-style: none;
	top: -020px;
	bottom: -020px;
	left: -020px;
	right: -020px;
	margin: 0;
	padding: 0;
}

.NMH-g-navicon .Jnmh-m-submenu .Jnmh-subli{
	position: absolute;
	width: 100%;height: 100%;
	transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transition: all 0.8s ease-in-out;
}

.Jnmh-m-submenu .Jnmh-subdl{
	position: absolute;
    left: 50%;
    bottom: 100%;
    width: 0;
    height: 0;
    line-height: 1px;
    margin-left: 0;
    background: #fff;
    border-radius: 50%;
    text-align: center;
    font-size: 1px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: none;
    transition: all 0.8s ease-in-out, color 0.1s, background 0.1s;
}
/*導(dǎo)航圖標(biāo)-展開菜單時(shí)*/
.NMH-g-navicon.Jnmh-open .Jnmh-m-submenu .Jnmh-subdl{
	width: 80px;
    height: 80px;
    line-height: 80px;
    margin-left: -40px;
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.1);
    font-size: 14px;
}
/*導(dǎo)航圖標(biāo)-三級(jí)菜單容器*/
.NMH-g-navicon.Jnmh-open .Jnmh-m-submenu .Jnmh-subdd{
	position: absolute;
	line-height: normal;
}

html代碼

<div id="nmh-navicon" class="NMH-g-plugin NMH-g-navicon">
		<button class="Jnmh-btnlogo"></button>
		<ins class="Jnmh-btnlogohover"></ins>
		<ul class="Jnmh-m-submenu">
			<li class="Jnmh-subli">
				<dl class="Jnmh-subdl">
					<dt class="NMH-subdt">電商平臺(tái)</dt>
					<dd class="NMH-subdd"></dd>
				</dl>
			</li>
			<li class="Jnmh-subli">
				<dl class="Jnmh-subdl">
					<dt class="NMH-subdt">選品平臺(tái)</dt>
					<dd class="NMH-subdd"></dd>
				</dl>
			</li>
			<li class="Jnmh-subli">
				<dl class="Jnmh-subdl">
					<dt class="NMH-subdt">會(huì)員升級(jí)</dt>
					<dd class="NMH-subdd"></dd>
				</dl>
			</li>
			<li class="Jnmh-subli">
				<dl class="Jnmh-subdl">
					<dt class="NMH-subdt">產(chǎn)品操作</dt>
					<dd class="NMH-subdd"></dd>
				</dl>
			</li>
			<li class="Jnmh-subli">
				<dl class="Jnmh-subdl">
					<dt class="NMH-subdt">個(gè)人中心</dt>
					<dd class="NMH-subdd"></dd>
				</dl>
			</li>
		</ul>
	</div>

javascript代碼

<script type="text/javascript" src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
	// 監(jiān)聽鼠標(biāo)移入logo事件
	$(document).on('mouseenter','.Jnmh-btnlogo',function(){
		$('#nmh-navicon').addClass('Jnmh-open');
		GtoggleNavlogo();
	});
	// 監(jiān)聽鼠標(biāo)移除導(dǎo)航球移除事件(展開收縮懸浮球?yàn)槭裁床恢苯颖O(jiān)聽#nmh-navicon而多了一步監(jiān)聽logo是為了減少邊緣觸發(fā))
	$(document).on('mouseleave','#nmh-navicon',function(){
		$('#nmh-navicon').removeClass('Jnmh-open');
		GtoggleNavlogo();
	});
	var GtoggleNavlogo = function(){
	    var li = $('#nmh-navicon').find('.Jnmh-subli');
	    var lilen = li.length;
	    var avgDeg =  180/(lilen-1);// 平均角度
	    var initDeg = 0;// 起始方向角度
	    if($('#nmh-navicon').hasClass('Jnmh-onleft')){
	    	// 如果懸浮球被拖拽到左邊,則二級(jí)菜單則顯示右側(cè)
	    	li.css({transform: 'rotate(0deg)'});
	    	initDeg =  180;
	    }else{
	    	// 默認(rèn)懸浮球在右邊,二級(jí)菜單顯示在左側(cè)
	    	li.css({transform: 'rotate(-360deg)'});
	    }
	    for(var i=0,j=lilen-1; i<lilen; i++,j--) {
	        var d =  initDeg - (i*avgDeg);
	        var z = initDeg?j:i;
	        // console.log(d);
	        $('#nmh-navicon').hasClass('Jnmh-open') ? GrotateNavlogo(li[z],d) : GrotateNavlogo(li[z],0);
	    }
	};
	var GrotateNavlogo = function(dom,deg){
		$({a:0}).animate({a:deg}, {
	        step: function(now,fx) {
	            $(dom).css({ transform: 'rotate('+now+'deg)' });
	            $(dom).children().css({ transform: 'rotate('+(-now)+'deg)' });
	        }, duration: 0
	    });
	}

	// 鼠標(biāo)拖動(dòng)logo移動(dòng)
	$(document).on('mousedown','.Jnmh-btnlogo',function(e_down){
		var wrap = $('#nmh-navicon');
		wrap.removeClass('Jnmh-open');
		$('.Jnmh-m-submenu').hide();
		GtoggleNavlogo();
		
		var positionDiv = wrap.offset();
	    var distenceX = e_down.pageX - positionDiv.left;
	    var distenceY = e_down.pageY - positionDiv.top + $(document).scrollTop();
		$(document).mousemove(diy_move);
		function diy_move(e_move){
			var x = e_move.pageX - distenceX;
	        var y = e_move.pageY - distenceY;

	        if (x < 0) {
	            x = 0;
	        } else if (x > $(document).width() - wrap.outerWidth(true)) {
	            x = $(document).width() - wrap.outerWidth(true);
	        }

	        if (y < 0) {
	            y = 0;
	        } else if (y > $(window).height() - wrap.outerHeight(true)) {
	            y = $(window).height() - wrap.outerHeight(true);
	        }

	        $(wrap).css({
	            'left': x + 'px',
	            'top': y + 'px'
	        });
		}
		$(document).mouseup(function() {
			var x = $(wrap).offset().left;
			var rm = '',ad = 'Jnmh-open';
			if(x > $(document).width()/2){
				x = $(document).width() - wrap.outerWidth(true) -10 ;
				rm = 'Jnmh-onleft';
			}else{
				x = 10;
				ad += ' Jnmh-onleft';
			}
			$(wrap).css({left: x + 'px'}).addClass(ad).removeClass(rm);
			$('.Jnmh-m-submenu').show();
			GtoggleNavlogo();
	        $(document).unbind('mousemove',diy_move);
	    });

	});

</script>

到此這篇關(guān)于html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)html滑動(dòng)仿懸浮球菜單內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標(biāo)簽:清遠(yuǎn) 內(nèi)蒙古 廣安 保定 陜西 山南 吳忠 上海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)》,本文關(guān)鍵詞  html,滑動(dòng),仿,懸浮,球,菜單,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于html滑動(dòng)仿懸浮球菜單效果的實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章