PhoneGap/Cordova学习笔记--5.添加事件处理

上一篇中,我们用HTML5创建了一个基本布局页面,本篇将对页面添加一些事件处理

  • 引入IScroll.js

    • 上一遍创建的布局中,当我们滑动页面,会发生标题栏和状态栏也会跟着滑上去,为解决这一问题,我们引入IScroll.js文件
      这里写图片描述

    • 浏览器打开iscrolljs.com → Download,我们移动端需要的是iscroll-lite.js文件,放进assets/www/js目录下,并在index.html中引用。

      这里写图片描述

  • 使用IScroll.js

    • 在index.html的列表div中添加ID
        <!-- 文件列表-->
        <div class="list" id="scroll-list">
  • iscroll的使用要求对应的属性position为absolute;overflow为hidden;在CSS文件中编辑我们的list div
    .content .list{
        position: absolute;
        left: 0;
        top: 1.5rem;
        right: 0;
        bottom:0;
        background-color: #ffffff;
        overflow: hidden;
    }
  • 在index.js文件中初始化
    $(function() {
        var size = $(window).width()/18;
        $("html").css("font-size", size);
        var scroll_list=new IScroll("#scroll-list");    
    });
现在执行项目就不会出现问题了,像Android中的ListView 

这里写图片描述

  • 添加Item点击事件,点击时删除该Item

    • 编辑index.js文件
    $(function() {
        var size = $(window).width() / 18;
        $("html").css("font-size", size);
        var myscroll = new IScroll("#scroll-list");
        //调用我们定义的事件函数
        myClickEvent($("#scroll-list li"), function() {
            $(this).remove();
        });
    });
    //定义点击事件函数,参数为点击的Item和事件的回调
    function myClickEvent(clickItem, callBack) {
        //点击前先移除绑定
        $(clickItem).unbind();
        //当点击开始时,绑定事件
        $(clickItem).bind("touchstart", function() {
            //设置Item为选中状态
            $(this).data("touchon", true);
            //设置Item选中时的背景颜色
            $(this).addClass("pressState");
        });
        //当点击结束时,绑定事件
        $(clickItem).bind("touchend", function() {
            //如果是选择的Item,让回调事件绑定执行回调函数
            if ($(this).data("touchon")) {
                callBack.bind(this)();
            }
            //移除背景色
            $(this).removeClass("pressState");
            //设置为非选中状态
            $(this).data("touchon", false);
        });
        //当事件为移动而非点击时,绑定事件
        $(clickItem).bind("touchmove", function() {
            $(this).data("touchon", false);
            $(this).removeClass("pressState");
        });
    };
在CSS文件中,添加按下时的背景色
    .content .list ul li.pressState{
        background-color: #c0c0c0;
    }
  • 运行项目可以看到当点击时实现了Android中的selector效果,并把点击的Item删除,而移动时并不会删除Item

这里写图片描述

  • 在非移动端中,我们可以通过以下判断是否为可触碰设备,并将Item事件绑定为mousedown、mouseup即可
isTouchDevice='ontouchstart' in window || navigator.msMaxTouchPoints;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值