最近,刚好在研究微网站的制作,查阅了大量的资料都是关于微信3平台开发教程,几乎没有这类的介绍,不过都是第三方平台提供模板制作微站而已,后来很感谢柳峰博客最后写的微网站的解惑,
“什么是微网站?
微网站是新瓶装老酒,被一些搞营销的人给神化了,以至于很多开发者都在问什么是微网站,如何开发微网站。微网站本质上就是以微信浏览器为入口的手机网站(Web APP),能够兼容Android、iOS、WP等操作系统。开发微网站用到的技术与开发普通网站一样,都是基于HTML(HTML5)、CSS、Javascript等,所以有普通网站开发经验的开发者,完全有能力开发微网站。
PS:初学者以后再看到什么以“微”开头的新名词,例如:微商城、微客服、微统计,直接把“微”字去掉或者把“微”当作是“基于微信的”就不难理解了。”,
大部分都涉及html5的写法,这样就好理解了。。。还有就是参考了“微信生意宝”中的案例,里面的导航自己写了下demo,感觉还是很好理解的,下面上界面效果图
因为是用jq所写,需要引用库文件,这边使用的是在线的cdn地址:
复制代码 代码如下:
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
然后编写html导航结构
复制代码 代码如下:
<div class="quick"></div>
<div class="slideLeftMenu">
<div class="quick-toolbar">
<p class="toolbar-title">QUICK MENU</p>
<span class="toolbar-icon-delete"></span>
</div>
<div class="menuList">
<a class="list-item">
<p class="list-item-title">Home</p>
<span class="list-item-icon"></span>
</a>
<a class="list-item">
<p class="list-item-title">About Us</p>
<span class="list-item-icon"></span>
</a>
<a class="list-item">
<p class="list-item-title">Products</p>
<span class="list-item-icon"></span>
</a>
<a class="list-item">
<p class="list-item-title">News</p>
<span class="list-item-icon"></span>
</a>
<a class="list-item">
<p class="list-item-title">Contact Us</p>
<span class="list-item-icon"></span>
</a>
</div>
</div>
<div class="masklayer"></div>
这部分没有什么技术性,纯粹就是div结构
复制代码 代码如下:
<span style="white-space:pre"> </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 style="white-space:pre"> </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:这边有个问题,在滑动过程会出现滚动条,这样其实是非常不美观的,请问大牛们有办法解决吗??我把附件放资源那边了,麻烦下载运行看看,如果有什么地方不对劲请留言提出来哦~~非常感谢
相关推荐:
Linux ORCLE数据库增量备份脚本
JS 截取字符串substr 和 substring方法的区别
JS旋转的彩色文字轮转特效
关于页面优化和伪静态
jQuery与javascript对照学习 获取父子前后元素 实现代码
php与XML、XSLT、Mysql的结合运用实现代码
dropdownlist之间的互相联动实现(显示与隐藏)
正确维护配置Apache服务器的方法 保护系统安全
彻底解决页面文字编码乱码问题
php self,$this,const,static,-&gt;的使用
纯CSS 链接悬停提示效果代码
oracle 优化的一点体会
Javascript 定时器调用传递参数的方法
php 向访客和爬虫显示不同的内容
Mootools 1.2教程 Tooltips
Serv-U 无法连接到服务器127.0.0.1,端口43958 之解决办法
Marquee配合DIV实现的文字滚动效果代码
Oracle 添加用户并赋权,修改密码,解锁,删除用户的方法
Oracle 子程序参数模式,IN,OUT,NOCOPY
通过Mootools 1.2来操纵HTML DOM元素
javascript GUID生成器实现代码
jQuery toggle()设置CSS样式
sqlserver 字符串分拆 语句
sql 查询结果合并union all用法_数据库技巧
传智播客学习之JavaScript基础篇
根据鼠标的位置动态的控制层的位置
FreeTextBox(版本3.1.6)在ASP.Net 2.0中使用方法
apache启动报错:the requested operation has failed解决办法
javascript获得CheckBoxList选中的数量
access数据库用sql语句添加字段,修改字段,删除字段
模仿JQuery sortable效果 代码有错但值得看看
Jquery在IE7下无法使用 $.ajax解决方法
jquery 动态调整textarea高度
跨域表单提交状态的变相判断代码
IIS “另一个程序正在使用此文件,进程无法访问。”错误提示的解决办法
三位千万富翁告诉你 钱是怎么赚来的
浅析ASP.NET生成随机密码函数
从Oracle 表格行列转置说起第1/2页
防止SQLSERVER的事件探查器跟踪软件
.net 动态标题实现方法
ASP.NET 调用百度搜索引擎的代码
JavaScript 三种创建对象的方法
SQLSERVER中union,cube,rollup,cumpute运算符使用说明
PHP 木马攻击的防御设置方法
asp.net HttpHandler实现图片防盗链
浅谈javascript 面向对象编程
CSS Filter背景透明提示
jQuery Ajax之$.get()方法和$.post()方法
Javascript 解疑
js 数组实现一个类似ruby的迭代器