问题在哪?动态菜单条-------Day86
今天做了一个动态菜单条,先上图片,简单说一下我想实现的效果:
就是以下这个地方,随着鼠标指到哪,它就划到哪,并有一个惯性的幅度,并且滑动距离越远,停住的时候惯性越大,摆动幅度越大,这就是我大概想实现的效果。
这样我再上一下代码:
html部分:
<center>
<div id="menu">
<ul id="book" onmouseover="choose(event)">
<li class="selected"><a href="#">玄幻</a></li>
<li><a href="#">武侠</a></li>
<li><a href="#">仙侠</a></li>
<li><a href="#">穿越</a></li>
<li><a href="#">同人</a></li>
<li><a href="#">网游</a></li>
<li><a href="#">都市</a></li>
<li><a href="#">历史</a></li>
<li id="bar"></li>//这个地方的实现是跟我自己想的有些出入的,可是发现还是这个好
</ul>
</div>
</center>
CSS部分:
* { margin:0; padding:0; }
body { width:100%; height:100%; overflow:auto; }
ul{width:800px;position:relative;margin-top:100px;background:grey;height:30px;}
li{width:70px;height:30px;line-height:30px;border-radius:10px;float:left;margin-left:20px;background:#fff0f0;position:relative;z-index:2;list-style:none;}
a{text-decoration:none;}
.selected{font-weight:bold;background:#ccc;}
#bar{padding-bottom:0px;width:70px;height:5px;z-index:4;position:absolute;background:red;bottom:-10px;}//这个地方bottom为负的
js部分:
var ulpart=null;//ul部分
var eachli=null;//li部分
var slide=null;//滑动部分
var speed=0;//移动速度
var fudu=7;//最后停下来时的惯性幅度
var move=null;//移动
var begin = 0;//開始的li部分
var stage = 0;//移动滑过li的个数
var now = 0;//当前的li部分
window.onload=function(){
ulpart=document.getElementById("book"); //获取ul对象
eachli=ulpart.getElementsByTagName("li");//获取li对象
slide=document.getElementById("bar");//获取滑动模块对象
for(var i=0;i<eachli.length;i++){
if(eachli[i]!=slide){
eachli[i].onmouseover=change;
}
}
}
function change(){
for(var i=0;i<eachli.length;i+=1){
if(eachli[i]===this){//这个地方的this实在是妙啊,好用
var target=(eachli[i].offsetWidth+20)*i;//当前li的左边距第一个li的左边的距离,20为li之间距离
now=i;//当前li
stage = parseInt(now - begin);//要移动的方向,正的是向右,负的是向左
if(move){
clearInterval(move);
}
if(stage>0){
move=setInterval("go("+target+")",30);//右移
}else{
move=setInterval("back("+target+")",30);//左移
}
begin=now;//将当前位置该为初始位置
}
eachli[i].className="";
this.className="selected";
}
}
function go(target){
var left=slide.offsetLeft;
speed+=fudu;
left+=speed;//移动速度加快的同一时候,距离变远
if(left>=target){//一旦超出距离
speed*=-1;//惯性抖动效果,这个效果也时管时无论,问题在哪呢?
if(Math.abs(speed)<=fudu){
clearInterval(move);
move=null;
}
left=target;
}
slide.style.left=left+"px";
}
function back(target){
if(slide.offsetLeft===target){
clearInterval(move);
move=null;
}else{
speed=(target-slide.offsetLeft)/5;
slide.style.left=slide.offsetLeft+speed+"px";
}
}
惯性的抖动效果,在前面做掉落抖动的效果的时候以前碰到过,可是这次效果时管时无论,问题到底在哪呢,实在有些困了,先睡,有大神路过的话请指教啊。
多希望能够有那么一个地方,明媚却不忧伤
问题在哪?动态菜单条-------Day86的更多相关文章
- Delphi编程中动态菜单要点归纳
一.创建菜单并添加项目 在设计程序时,有时需要动态创建菜单, 通常使用以下的语句: PopupMenu1 := TPopupMenu.Create(Self); Item := TMenuIte ...
- Django项目:CRM(客户关系管理系统)--82--72PerfectCRM实现CRM动态菜单和角色
#models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...
- ASP。使用依赖注入的asp.net Core 2.0用户角色库动态菜单管理
下载source code - 2.2 MB 介绍 在开始这篇文章之前,请阅读我的前一篇文章: 开始使用ASP.NET Core 2.0身份和角色管理 在上一篇文章中,我们详细讨论了如何使用ASP.N ...
- winform快速开发平台 -> 通用权限管理之动态菜单
这几个月一直忙APP的项目,没来得及更新项目,想想该抽出时间整理一下开发思路,跟大家分享,同时也希望得到宝贵的建议. 先说一下我们的权限管理的的设计思路,首先一个企业信息化管理系统一定会用到权限管理, ...
- WIN 下的超动态菜单(三)代码
WIN 下的超动态菜单(一)简介 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ 超动态 ...
- WIN 下的超动态菜单(一)
WIN 下的超动态菜单(一)介绍 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ ...
- WIN 下的超动态菜单(二)用法
WIN 下的超动态菜单(一)简介 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ ...
- 实战android菜单项之XML加载菜单与动态菜单项[转]
原文地址:http://blog.csdn.net/kaiwii/article/details/7767225 自定义android应用程序的菜单项首先要知道切入点.经过学习,知道主要是两个Acti ...
- JS打字效果的动态菜单代码分享
这篇文章主要介绍了JS打字效果的动态菜单,推荐给大家,有需要的小伙伴可以参考下. 这是一款基于javascript实现的打字效果的动态菜单特效代码,分享给大家学习学习. 小提示:浏览器中如果不能正常运 ...
随机推荐
- JAVA 线程学习 - Thread了解
public class ThreadKnow { private TimeThread timeThread; private boolean flag; public ThreadKnow() { ...
- 过拟合/欠拟合&logistic回归等总结(Ng第二课)
昨天学习完了Ng的第二课,总结如下: 过拟合:欠拟合: 参数学习算法:非参数学习算法 局部加权回归 KD tree 最小二乘 中心极限定律 感知器算法 sigmod函数 梯度下降/梯度上升 二元分类 ...
- 从一个App跳转到另一个App
在跳入App的info中配置Bundle identifier 在跳入App的info中配置URL Schemes 在另一个应用程序中按照上边的操作添加openURL并运行,就可以跳转了 调用open ...
- [置顶] JDK-Future 模式和实现
最近的项目用到了多线程,发现java.util.concurrent.Future蛮好用的. 像平时,写多线程一般使用Thread/Runnable,直接扔给线程池执行就好了.但是遇到了一些需要获取线 ...
- CSS3媒体查询(Media Queries)
媒体类型: all 所有设备 screen 电脑显示器 handheld 便携设备 tv 电视类型设备 print 打印用纸打印预览视图 关键字 and not(排除某种设备) only(限定某种设备 ...
- 玩2k16
2k是我最喜欢的游戏啦,平时无聊了都会搞两盘.现在到2k16了,玩游戏时碰到一些麻烦,记录便查. 我哥一直说他的电脑玩2K16非常卡,根本玩不了,但是他的电脑配置可比我的高啊,我玩起溜溜地,喊他把配置 ...
- (IOS)国际本地化设置
首先New File,在Resource中选择Strings File: 然后命名该strings文件,必须命名为 Localizable : 再者选中该strings文件,在Localization ...
- MVC3 Html.ActionLink
以下使用参数文字说明: linkText:生成的链接所显示的文字 类型:string actionName:对应控制器的方法 类型:string routeValues:向对应的action传递的 ...
- PencilDraw: 用简化的C语言画图!
最近做的一个东西,不过功能还不是太完善,而且界面极丑.慢慢改进吧. 点这里打开!
- linux下观看b站视频,解决字体乱码
如图: 各种字体都显示为方块,解决办法也很简单. 点击视频右边的齿轮,也就是设置,更改字体. 默认的微软雅黑字体,一般换成其他的字体应该都能正常显示. 这是为更改后: