位置: 编程技术 - 正文

基于zepto的移动端轻量级日期插件--date_picker

编辑:rootadmin

推荐整理分享基于zepto的移动端轻量级日期插件--date_picker,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

做过移动Web开发的同学都知道,移动端日期选择是很常见的需求。在PC端,我们有很丰富的选择,比较出名的就有Mobiscroll和jQuery UI Datepicker。个人看来,这些插件存在的两个显而易见的问题,第一是过重的依赖,对于jQuery的插件,已经强制依赖了多k的庞然大物,把很多移动端项目拒之门外;第二是太过强大的功能,很多插件花百分之八十的时间去完善插件百分之二十炫酷的额外功能,导致代码量变大,配置繁杂。所以一款少依赖、轻量级和使用简单的移动端日期选择插件是非常必要的。本文简单介绍近来写的一款基于zepto的移动端轻量级日期插件--date_picker。

插件设计原则

只保留最必要的功能

日期选择插件无非就是可以进行年、月、日选择,并且提供必要的年月切换动画特效,至于什么最小时间、最大时间、主题定制,概不在本插件功能范围。

保留必要的依赖

本插件虽说是基于zepto,实际上还隐性依赖了Github上面一个比较牛的库fastclick。我们知道,移动端点击事件处理有两个常见的问题:(1)移动端click事件有ms,通常采用touch事件来代替click事件来提高灵敏性;(2)touch事件会存在穿透的问题,一般插件都不用touch事件;基于这两个问题,fastclick做了兼容,只需要简单调用它提供的api就能够愉快得和原本一样调用click事件,所以这个依赖不能省。至于依赖zepto,实际上是可有可无的,一来博主平时工作都是写原生js的,不用插件也没多大的感觉,二来插件受众面就会小一些。不过鉴于zepto在移动端已然和zepto在PC端一样如鱼得水,就毫不客气采用了。

既能够支持模块化又能本地引用文件使用的

久远一点的插件基本都是让你下载一个文件,然后用script去引用,这样本无可厚非,只不过放着最大的包管理器npm不用,岂不是对不起页面仔这个称号。所以本插件支持文件引用也支持CMD方式的模块引用。

功能介绍

直接上图:

基于zepto的移动端轻量级日期插件--date_picker

技术细节

transitionEnd事件

插件的主面板是当前月份的天数详情,如果点击上一个月或者下一个月插件需要计算出上一个月或者下一个月的天数信息,然后插入到DOM节点中。在插入到DOM节点之后,就需要采用动画效果来显示最新的一月并且褪去老的一个月,采用的方式是CSS2d转化加过渡。我们需要处理的就是在旧的一个月褪去看不见的时候及时从DOM树中删除,不然如果用户一直点下一个月或者上一个月的话,内存会炸的。为了实现这个移除功能,一个办法是采用setTimeout事件在特定的时间去删除节点,经过尝试,发现由于Javascript定时器不准确的特性和前后一个月切换带来的逻辑复杂度增加,这种方案很不可行。于是,本插件采用了第二个方案:transitionEnd事件。直接引用一下MDN的介绍:

也就是只要你不去随便乱动元素的CSS属性,在动画完成的时候,你就可以执行相应的操作(删除节点)。再来看看兼容性:

对于移动Web开发足矣!

最后就是在绑定事件的兼容性问题,不同厂商对于这个事件的定义并不一致,比如IOS里面监听的是transitionend事件,但是在安卓里面监听transitionend事件完全没反应,经过一番Google,发现安卓需要监听webkitTransitionEnd事件。为了解决绑定事件时候的兼容性问题,就需要检测浏览器到底支持哪种事件。下面贴上Stackoverflow上面一个问答的代码片段:

安装使用

安装

支持下面两种方式

git clone之后直接拷贝引用bin文件夹下面的datepicker.min.css和datepicker.min.js 从npm下载安装:npm install --save date_picker

使用

引用样式datepicker.min.css引用datepicker.min.js或者引用模块var DatePicker = require('date_picker');实例化组件,绑定插件日期选择完成之后的回调函数

插件外置两个API: open和close,其中特别注意上面demo中_date在获取焦点之后里面强制去除了焦点,是为了避免安卓下面为input标签设置readonly属性并不能禁止原生键盘弹出的问题。

jquery实现页面常用的返回顶部效果 本文实例为大家分享了jquery实现返回顶部效果的全部代码,供大家参考,具体内容如下效果图:实现代码:!DOCTYPEhtmlhtmllang="en"headmetacharset="UTF-8"title返回

jQuery实现TAB选项卡切换特效简单演示 本文实例为大家分享jQuery实现TAB选项卡切换特效,供大家参考,具体内容如下1、tab切换on!DOCTYPEhtmlhtmllang="en"headmetacharset="UTF-8"titlejQuerytab切换/titlestyletype

简单的jQuery banner图片轮播实例代码 朋友给我看了一个轮播效果,把js下载一看,丫丫的一个这么简单的效果,这么的就能写个几百行的,严重影响浏览器加载速度嘛,以为人家宽带流量不

标签: 基于zepto的移动端轻量级日期插件--date_picker

本文链接地址:https://www.jiuchutong.com/biancheng/383043.html 转载请保留说明!

上一篇:jquery ajax双击div可直接修改div中的内容

下一篇:jquery实现页面常用的返回顶部效果(jquery 弹出页面)

  • 2021年餐饮业的税率是多少?
  • 财务软件应交增值税明细科目
  • 等线支付给劳务派遣单位的工资怎么做账
  • 从价计征房产税怎么算 原值和出租房原值
  • 跨月发票红字冲销账务处理
  • 增值税抵扣可以跨月吗
  • 员工个人承担的保险分录
  • 无偿赠送商品要纳企业所得税吗
  • 临时设施费怎么结算
  • 社保扣除的是当月还是上个月的
  • 交房租对方开发票怎么开
  • 现金收取业务办理流程
  • 预缴物业费是否符合法律规定
  • 差额征税条件
  • 公司为员工承担的个税可以税前扣除吗
  • 小规模纳税人申报表2023年怎么填写
  • 汇算清缴涉及到哪些科目的调整
  • 建材销售公司需要交哪些税
  • 外汇汇兑损益怎么做账
  • 房地产开发企业资质证书
  • 固定资产核销怎么做
  • 怎么查询企业收款账号
  • 如何计算每个月的天数
  • 物流运输公司要交税吗
  • 任务栏图标调大了怎么办
  • u盘安装win8系统步骤
  • php快速查找
  • PHP:imagecopyresampled()的用法_GD库图像处理函数
  • php目录浏览
  • php操作mysql数据库
  • 红字增值税发票怎么开具图解
  • 【第二趴】uni-app开发工具(手把手带你安装HBuilderX、搭建第一个多端项目初体验)
  • cvpr best
  • Web 1.0、Web 2.0 和 Web 3.0 之间的比较
  • tracetcp命令
  • phpcms教程
  • 所得税季度申报表怎么填
  • 交易性金融资产包括哪些项目
  • 注册公司行业分类有多少种
  • 税金及附加也是费用吗
  • 赔偿款收据样本
  • 建账在1月份如何录入期初
  • 当月已付款, 没收到发票怎么做账
  • 当月没有发放工资是不是就不用申报个税
  • 会计准则中规范性的内容
  • 补缴的土地价款怎么算费用
  • 小规模纳税人能开6%增值税专用发票吗
  • 营业执照作废声明
  • 企业净资产如何算
  • 清算资金往来借贷方什么意思
  • 所得税汇算清缴退税会计分录怎么做
  • 如何查看员工社保
  • 人工工资会计科目
  • 库存现金期末余额在哪方
  • 旅游应当提示参加团队旅游的旅游者按照规定购买什么
  • sql server常用管理工具中,用于访问
  • ubuntu系统升级后无法进入系统
  • win7系统如何隐藏桌面
  • u极速u盘装系统
  • win8.1网络不可用怎么办
  • linux指令系统
  • android内存优化面试
  • 原生java web
  • 微信小程序实现文件上传
  • 编程python怎么学
  • ssm vue
  • jquery的dialog怎么使用
  • 如何用nodejs搭建服务端
  • unity 3d ui
  • node.js上传文件
  • shell bash sh
  • Metaio in Unity3d 教学--- 三. 使用ID Marker作为扫描目标
  • 全面解析日本失去的十年
  • 新疆国税网上营业厅
  • 贵州网上税务局官网登录
  • 净化水服务税务分类
  • 进项税和销项税怎么抵扣举例说明
  • 税务局政务公开目录
  • 包装种类代码表集装箱
  • 江西省国家税务局网站
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设