首页 > 移动平台 > 详细

JS三教九流系列-Zepto.js-为移动端开发的类库

时间:2015-08-17 12:23:50      阅读:219      评论:0      收藏:0      [点我收藏+]

zepto.js的api地址 http://www.css88.com/doc/zeptojs_api/ 

类库源码下载http://www.zeptojs.cn/ 滚动当前页面,看到这部分点击下载

技术分享

和使用jquery一样,我们只要html页面引入即可。
zepto的api与jq几乎一样,同时各个接口名字也是一样的,我们只要按着写jq一样去写zepto就好了,既然这样,我们为何要用zepto,主要就是zepto提供时触摸事件,为开发移动端的更好处理。

jq是为多个浏览器支持的类库,并没有封装上touch事件,如果我们的项目是pc或者虽然是移动端,但是没有很多触摸事件的效果,我们选择jq即可,我们可以看出,我们采用zepto的时候

手机项目的开发,需要触摸事件。

zepto的支持是高级浏览器,ie10以上。


1.zepto.js的helloworld输出

我们学习之前,需要保证对jq有很熟练的使用技巧,我们使用zepto,基本的调用如下

<!DOCTYPE html>
<html>
<head>
<title>demo1</title>

</head>
<body>
   zepto.js
</body>
<script type="text/javascript" src="zepto.min.js"></script>
<script type="text/javascript">
// 当页面ready的时候,执行回调:
Zepto(function($){
  alert(‘helloworld!‘)
});
</script>
</html>

zeopt的代码我们是放在

Zepto(function($){

  //code

});

的内部,对比jq,不过是把$换成Zepto了。

2.zepto.js的基本使用

我们获取div的内容,点击修改按钮,修改div内容,代码如下

<!DOCTYPE html>
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<title>demo1</title>

</head>
<body>
   <div class="con">zepto.js
   </div>
   <span class="edit">修改</span>
</body>
<script type="text/javascript" src="zepto.min.js"></script>
<script type="text/javascript">
// 当页面ready的时候,执行回调:
Zepto(function($){
  $(".edit").click(function(){
  	$(".con").html("我被修改了!");
  });
});
</script>
</html>

很完美,不过我们监听事件,同时zepto推荐的而是通过on的处理,我们使用on处理,代码如下

<!DOCTYPE html>
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<title>demo1</title>

</head>
<body>
   <div class="con">zepto.js
   </div>
   <span class="edit">修改</span>
</body>
<script type="text/javascript" src="zepto.min.js"></script>
<script type="text/javascript">
// 当页面ready的时候,执行回调:
Zepto(function($){
  $(".edit").on("click",function(){
  	$(".con").html("我被修改了!");
  });
});
</script>
</html>

使用被推荐的写法,才会减少问题的出现。通过这段的测试,我们知道zepto的使用jq几乎一样的

3.zepto.js的触摸事件使用

这才是我们会选择zepto而不使用jq的原因,就是使用它提供好的touch模块,我们先了解这些接口

“touch”模块添加以下事件,

tap —元素tap的时候触发。

singleTap and doubleTap — 这一对事件可以用来检测元素上的单击和双击。(如果你不需要检测单击、双击,使用 tap 代替)。

longTap — 当一个元素被按住超过750ms触发。

swipeswipeLeftswipeRightswipeUpswipeDown — 当元素被划过时触发。(可选择给定的方向)

我们给元素添加事件处理,看看每个触摸事件区别,代码如下(需要引用zepto类库

<!DOCTYPE html>
<html>
<head>
<title>iPhone.Zepto</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="format-detection" content="telephone=no" />
<script src="zepto.min.js"></script>
<style type="text/css">
*{ margin: 0; padding: 0;}
ul{ list-style: none;}
.touch{ width:300px; margin:20px; background:#C96; border-radius:8px; height:40px; line-height:40px; text-align:center;}
</style>
</head>
<body>
<div class="touch touch1">点击一下触发tap</div>
<div class="touch touch2">点击时间超过750ms触发longTap</div>
<div class="touch touch3">滑动一下触发swipe</div>
<div class="touch touch4">向左滑动触发swipeLeft</div>
<div class="touch touch5">向右滑动触发swipeRight</div>
<div class="touch touch6">向上滑动触发swipeUp</div>
<div class="touch touch7">向下滑动触发swipeDown</div>
</body>
<script type="text/javascript">
Zepto(function($){
  
 $(".touch1").tap(function(){
  alert($(this).html())
 });
 $(".touch2").longTap(function(){
  alert($(this).html())
 });
 $(".touch3").swipe(function(){
  alert($(this).html())
 });
 $(".touch4").swipeLeft(function(){
  alert($(this).html())
 });
 $(".touch5").swipeRight(function(){
  alert($(this).html())
 });
 $(".touch6").swipeUp(function(){
  alert($(this).html())
 });
 $(".touch7").swipeDown(function(){
  alert($(this).html())
 });
 
 
}); 
</script>
</html>
<!--
//点击事件
 $("#rr").on(‘click‘, function(e){
  var tempdeg=$("#aa").css(‘transform‘);
  tempdeg=tempdeg.split(‘deg‘)[0].split(‘(‘)[1];
  $("#aa").css(‘transform‘,‘rotate(‘+parseInt(tempdeg-90)+‘deg)‘);
  $("#aa").children(‘a‘).css(‘transform‘,‘rotate(‘+parseInt(-(tempdeg-90))+‘deg)‘);
 });-->

其他的事件我就不介绍了,jq我们都已经了解到了,我们利用zepto提供的触摸事件,做一些移动端网页常用的效果;

4.zepto.js利用触摸事件开发实例

实例1:具有滑动事件的tab切换

我们了解到额tab切换,是在点击选项内容是,切换下面的内容,在这种功能的基础上,我们对内容区进行向左滑动,和向右滑动,也可以切换内容区,并且选项卡自动获取焦点,zepto的tab切换代码如下:

<!DOCTYPE html>
<html>
<head>
<title>iPhone.Zepto</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="format-detection" content="telephone=no" />
<script src="zepto.min.js"></script>
<style type="text/css">
*{ margin: 0; padding: 0;}
ul{ list-style: none;}
/*demo*/
.tab1{height:400px; width:400px;}
.tabnav{height:50px; line-height:50px;}
.tabnav span{ cursor:pointer; margin:0 10px;}
.tabnav .fou{ color:#36F;}
.tabbox{height:350px; background:#FCC;}
</style>
</head>
<body>
<div class="tab1">
    <div class="tabnav">
        <span class="fou">111</span>
        <span>222</span>
        <span>333</span>
    </div>
    <div class="tabbox">
        <div>111111</div>
        <div style="display:none;">22222222222</div>
        <div style="display:none;">33333333</div>
    </div>
</div>
</body>
<script type="text/javascript">
Zepto(function($){
  
 $(".tab1").find(".tabnav").children().click(function(){
   $(".tab1").find(".tabbox").children().eq($(this).index()).show().siblings().hide();
   $(this).addClass("fou").siblings().removeClass("fou");
 });
 
 
}); 
</script>
</html>

这是最基本的tab切换,我们还要对内容区添加触摸事件,进行滑动切换的操作,代码如下

<!DOCTYPE html>
<html>
<head>
<title>iPhone.Zepto</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="format-detection" content="telephone=no" />
<script src="zepto.min.js"></script>
<style type="text/css">
*{ margin: 0; padding: 0;}
ul{ list-style: none;}
/*demo*/
.tab1{height:400px; width:300px;}
.tabnav{height:50px; line-height:50px;}
.tabnav span{ cursor:pointer; margin:0 10px;}
.tabnav .fou{ color:#36F;}
.tabbox{height:350px;}
.tabbox div{ height:350px; background:#FCC;}
</style>
</head>
<body>
<div class="tab1">
    <div class="tabnav">
        <span class="fou">111</span>
        <span>222</span>
        <span>333</span>
    </div>
    <div class="tabbox">
        <div>111111</div>
        <div style="display:none;">22222222222</div>
        <div style="display:none;">33333333</div>
    </div>
</div>
</body>
<script type="text/javascript">
Zepto(function($){
 
 var index=0; 
 $(".tab1").find(".tabnav").children().click(function(){
   $(".tab1").find(".tabbox").children().eq($(this).index()).show().siblings().hide();
   $(this).addClass("fou").siblings().removeClass("fou");
   index=$(this).index();
 });
 var len=$(".tab1").find(".tabnav").children().length-1;
 $(".tab1").find(".tabbox").children().swipeLeft(function(){    
  if(index>=len){
   index=0;
  }else{
   index=index+1; 
  };
  $(".tab1").find(".tabbox").children().eq(index).show().siblings().hide();
  $(".tab1").find(".tabnav").children().eq(index).addClass("fou").siblings().removeClass("fou");
  
 });
 $(".tab1").find(".tabbox").children().swipeRight(function(){
  if(index<=0){
   index=len;
  }else{
   index=index-1; 
  };
  $(".tab1").find(".tabbox").children().eq(index).show().siblings().hide();
  $(".tab1").find(".tabnav").children().eq(index).addClass("fou").siblings().removeClass("fou");  
 });
 
}); 
</script>
</html>

实例2:结合css3的变换旋转,做圆形导航

我们见过这样的导航,一个圆形,按着指定的角度排列分开,截图如下

技术分享

点击圆圈内容可以链接到新页面,单击中间的圆形区域,根据手势左右,进行转盘切换

点击左右按钮,也可以进行转盘切换

示例代码如下:

<!DOCTYPE html>
<html>
<head>
<title>iPhone.Zepto</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="format-detection" content="telephone=no" />
<script src="zepto.min.js"></script>
</head>
<body>
<nav style="position:relative; height:100px;">
    <div id="aa" style=" width:200px; height:200px; margin-left:-100px; background:#06C; position:absolute; top:-100px;; left:50%;
        transform-origin:center center;transition:all .3s linear 0s;transform:rotate(0deg); border-radius:100px;">
        <a style=" position:absolute; width:50px; height:50px; background:#9C0;border-radius:25px; margin-left:-25px;left:100px; top:-25px; text-align:center; line-height:50px;transition:all .3s linear 0s; transform-origin:center center;transform:rotate(0deg);">11</a>
        <a style=" position:absolute; width:50px; height:50px; background:#9C0;border-radius:25px; margin-left:-25px;left:200px; top:75px; text-align:center; line-height:50px;transition:all .3s linear 0s; transform-origin:center center;transform:rotate(0deg);">22</a>
        <a style=" position:absolute; width:50px; height:50px; background:#9C0;border-radius:25px; margin-left:-25px;left:100px; top:175px; text-align:center; line-height:50px;transition:all .3s linear 0s; transform-origin:center center;transform:rotate(0deg);">33</a>
        <a style=" position:absolute; width:50px; height:50px; background:#9C0;border-radius:25px; margin-left:-25px;left:0px; top:75px; text-align:center; line-height:50px;transition:all .3s linear 0s; transform-origin:center center;transform:rotate(0deg);">456</a>
    </div>
</nav>
<span id="ll" style=" display:inline-block; height:30px; line-height:30px; text-align:center; background:#0CF; border-radius:10px;">左动</span>
<span id="rr" style=" display:inline-block; height:30px; line-height:30px; text-align:center; background:#0CF; border-radius:10px;">右动</span>
<p>案例被手机支持,可用模拟器,点击按钮可旋转,在导航区左右滑动可旋转</p>
</body>
<script type="text/javascript">
Zepto(function($){
 
 //手滑事件
 $("#aa").swipeRight(function(){
  var tempdeg=$(this).css(‘transform‘);
  tempdeg=tempdeg.split(‘deg‘)[0].split(‘(‘)[1];
  $(this).css(‘transform‘,‘rotate(‘+parseInt(tempdeg-90)+‘deg)‘);
  $(this).children(‘a‘).css(‘transform‘,‘rotate(‘+parseInt(-(tempdeg-90))+‘deg)‘);
 }); 
 $("#aa").swipeLeft(function(){
  var tempdeg=$("#aa").css(‘transform‘);
  tempdeg=tempdeg.split(‘deg‘)[0].split(‘(‘)[1];
  $("#aa").css(‘transform‘,‘rotate(‘+(parseInt(tempdeg)+90)+‘deg)‘);
  $("#aa").children(‘a‘).css(‘transform‘,‘rotate(‘+(-(parseInt(tempdeg)+90))+‘deg)‘);
 });
 //点击事件
 $("#rr").on(‘click‘, function(e){
  var tempdeg=$("#aa").css(‘transform‘);
  tempdeg=tempdeg.split(‘deg‘)[0].split(‘(‘)[1];
  $("#aa").css(‘transform‘,‘rotate(‘+parseInt(tempdeg-90)+‘deg)‘);
  $("#aa").children(‘a‘).css(‘transform‘,‘rotate(‘+parseInt(-(tempdeg-90))+‘deg)‘);
 });
 $("#ll").on(‘click‘, function(e){
  var tempdeg=$("#aa").css(‘transform‘);
  tempdeg=tempdeg.split(‘deg‘)[0].split(‘(‘)[1];
  $("#aa").css(‘transform‘,‘rotate(‘+(parseInt(tempdeg)+90)+‘deg)‘);
  $("#aa").children(‘a‘).css(‘transform‘,‘rotate(‘+(-(parseInt(tempdeg)+90))+‘deg)‘);
 });
 
}); 
</script>
</html>

实例3:触摸事件的焦点图实现

我们已经做过带滑动的tab切换效果,其实效果很像了,我们在加上动画处理就好了!!!!!!

 

 



JS三教九流系列-Zepto.js-为移动端开发的类库

原文:http://my.oschina.net/u/2352644/blog/493354

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!