手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >用jquery写的菜单从左往右滑动出现
用jquery写的菜单从左往右滑动出现
摘要:最近,刚好在研究微网站的制作,查阅了大量的资料都是关于微信3平台开发教程,几乎没有这类的介绍,不过都是第三方平台提供模板制作微站而已,后来很...

最近,刚好在研究微网站的制作,查阅了大量的资料都是关于微信3平台开发教程,几乎没有这类的介绍,不过都是第三方平台提供模板制作微站而已,后来很感谢柳峰博客最后写的微网站的解惑,

“什么是微网站?

微网站是新瓶装老酒,被一些搞营销的人给神化了,以至于很多开发者都在问什么是微网站,如何开发微网站。微网站本质上就是以微信浏览器为入口的手机网站(Web APP),能够兼容Android、iOS、WP等操作系统。开发微网站用到的技术与开发普通网站一样,都是基于HTML(HTML5)、CSS、Javascript等,所以有普通网站开发经验的开发者,完全有能力开发微网站。

PS:初学者以后再看到什么以“微”开头的新名词,例如:微商城、微客服、微统计,直接把“微”字去掉或者把“微”当作是“基于微信的”就不难理解了。”,

大部分都涉及html5的写法,这样就好理解了。。。还有就是参考了“微信生意宝”中的案例,里面的导航自己写了下demo,感觉还是很好理解的,下面上界面效果图

1

因为是用jq所写,需要引用库文件,这边使用的是在线的cdn地址:

复制代码 代码如下:

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>

然后编写html导航结构

复制代码 代码如下:

<div></div>

<div>

<div>

<p>QUICK MENU</p>

<span></span>

</div>

<div>

<a>

<p>Home</p>

<span></span>

</a>

<a>

<p>About Us</p>

<span></span>

</a>

<a>

<p>Products</p>

<span></span>

</a>

<a>

<p>News</p>

<span></span>

</a>

<a>

<p>Contact Us</p>

<span></span>

</a>

</div>

</div>

<div></div>

这部分没有什么技术性,纯粹就是div结构

复制代码 代码如下:

<span> </span>*{ margin:0; padding:0;}

body{

font-size:1em;

height:100%;

margin:0;

padding:0;

}

复制代码 代码如下:

/*这边是快捷按钮的样式,使用了css3属性写法,没考虑ie8-*/

.quick{

position:relative;

left:0;

top:0;

width:100%;

height:32px;

background:-webkit-gradient(linear, left top, left bottom, from(#99f), to(#96f));

background:-webkit-linear-gradient(#99f, #96f);

background: -moz-linear-gradient(#99f, #96f);

background: -ms-linear-gradient(#99f, #9f);

background: -o-linear-gradient(#99f, #96f);

background: linear-gradient(#99f, #96f);

}/*这边就是导航的css了,*/

<span> </span>.slideLeftMenu{

display:none;

width:272px;

min-height:100%;

background:#3d3d3d;

position:absolute;

right:0;

top:0;

z-index:3;

}

.slideLeftMenu .quick-toolbar,

.slideLeftMenu .list-item{

display:block;

width:100%;

float:left;

height:42px;

line-height:42px;

background:-webkit-gradient(linear, left top, left bottom, from(#444), to(#222));

background:-webkit-linear-gradient(#444, #222);

background: -moz-linear-gradient(#444, #222);

background: -ms-linear-gradient(#444, #222);

background: -o-linear-gradient(#444, #222);

background: linear-gradient(#444, #222);

}

.quick-toolbar .toolbar-title{

float:right;

color:#fff;

margin-right:10px;

}

.quick-toolbar .toolbar-icon-delete{

float:left;

width:18px;

height:18px;

margin:11px 0 0 10px;

background:url(images/icons-18-white.png) -73px -1px #212121;

border-radius:9px;

}

.menuList .list-item-title{

float:left;

font:blod 1.125em Arial, Helvetica, sans-serif;

color:#fff;

text-indent:0.75em;

text-align:left;

border:solid 0px red;

}

.menuList .list-item-icon{

float:right;

width:18px;

height:18px;

margin:11px 10px 0 0;

background:url(images/icons-18-white.png) -108px -1px #212121;

border-radius:9px;

}/*遮罩的css部分,这些绝大部分都是使用绝对定位实现的,因为我们要让导航从右侧平滑的飞入*/

.masklayer{

display:none;

width:100%;

height:100%;

position:absolute;

left:0;

top:0;

background:#000;

opacity:0.6;

z-index:2;

}

把css都写好了,也就完成一大半了,剩下就是使用jq处理动画部分,如下代码

复制代码 代码如下:

window.QuickPanel = { //定义全局函数

'isOpened': false,

'opened': function(){ //定义面板打开的方法,打开的同时如果点击了背景层和快捷按钮层,执行关闭面板

$masklayer.fadeIn().on("click" ,function(){

window.QuickPanel.closed();

});

$quickpanel_toolbar.on("click" ,function(){

window.QuickPanel.closed();

});

$panel.css({ //从右边飞入,使用绝对定位来操作

"width":"272px",

"top":"-6px",

"right":"-272px"

}).show().animate({"right":"0"},function(){

window.QuickPanel.isOpened = true;

});

},

'closed': function(){ //定义关闭面板方法

$panel.css({"right":"0"}).show().animate({

"right":"-272px"

},function(){

$masklayer.fadeOut(); //这边才淡出的遮罩,我点击快的时候就会出问题。。。

window.QuickPanel.isOpened = false;

$panel.hide(); //等动画结束了吧菜单隐藏,不至于有滚动条

});

}

};

这部分是最重要的,我封装了个quickpanel的函数,里面有open和closed俩方法,,供我们其他dom元素点击调用会比较方便,最终实现就是图上的下效果,

ps:这边有个问题,在滑动过程会出现滚动条,这样其实是非常不美观的,请问大牛们有办法解决吗??我把附件放资源那边了,麻烦下载运行看看,如果有什么地方不对劲请留言提出来哦~~非常感谢

【用jquery写的菜单从左往右滑动出现】相关文章:

jQuery zTree加载树形菜单功能

jquery实现图片左右切换的方法

jQuery实现自动滚动到页面顶端的方法

JQuery中两个ul标签的li互相移动实现方法

jQuery实现在列表的首行添加数据

基于jQuery插件实现环形图标菜单旋转切换特效

jquery任意位置浮动固定层插件用法实例

jQuery使用zTree插件实现树形菜单和异步加载

全面详细的jQuery常见开发技巧手册

jQuery封装的tab选项卡插件分享

精品推荐
分类导航