js手机滑块模仿

点击文本框滑动选值

手机屏幕上的上下翻滚菜单使用JS实现.经过十几个小时的折磨,终于有了最初版本.实现办法如下描述:

一.要求和方法

1.一个input输入框,点击后弹出一个翻滚菜单盖在其上,翻滚选好后,点击确定.所选值就到了文本框里.
2.实现这个翻滚菜单使用如下办法:一个菜单DIV,里面是若干菜单项SPAN.菜单DIV设置有竖直滚动条,这样就能滚动菜单项.

菜单DIV的上层,有个包裹层,主要作用是遮住菜单DIV的滚动条.包裹层上还有一层菜单框,用于包裹所有菜单DIV,操作它的显示
和隐藏可以方便地打开关闭菜单.最后,INPUT 菜单框 按钮 放到一个DIV里.结构和主要设定如下:

div // 最外层包含所有 (相对定位)
 input // 输入框
 button // 按钮
div // 所有菜单外层 (相对定位,初始隐藏,长度设为input长度稍大于它)
 div // 菜单外层,为遮菜单DIV滚动条(相对定位,超出隐藏,宽度百分比值等于100/菜单DIV个数)
  div // 菜单面板层(滚动条,高度为菜单项3倍)
   span // 菜单,若干个(块级)
........可有多个菜单面板
3.遮挡滚动条:实现过程中,遮挡菜单DIV滚动条时费了很大劲.最终实现的办法是:将菜单DIV的宽度设为再加上它的滚动条的宽度.
这样一来,上层就显示不出多余的滚动条了,"超出部分隐藏了".那又如何得到菜单DIV宽度,和其滚动条宽度呢.这样.

var scrollbarWidth = menuDiv.offsetWidth - menuDiv.scrollWidth;
意思是offsetWidth这个包含滚动条在内的宽度,减去scrollWidth这个包含滚动区域不包含滚动条的宽度.
然后将菜单DIV的width设为offsetWidth加上上面得出的滚动条宽度值.就实现了
4.菜单出现位置:点击之后,要让它出现在INPUT的上层,左对齐,并且遮住INPUT.这主要是一个算TOP和LEFT的过程.它与INPUT同
级,父级为最外层DIV.这个要有相对定位属性.后面是用JQUERY的position()获取INPUT的位置的,如果不设的话
就错大了.TOP值好算,就是INPUT的outerHeight(),为了盖住INPUT,所以是负值,在前面加-号.
LEFT值和INPUT的左位移设置一样.其实可设为0,因为它们同级,且INPUT没有定位(默认0).但是为了让菜单跟着
INPUT框移动,则有必要这种灵活的计算.
5.遮住文本框:在手机上点击INPUT文本框时,出弹出手机上的输入法.但目前并不需要这个输入,所以不能让它弹出来.解决办法是
不让它点击文本框,在文本框上加一个透明的层,大小和文本框一样,刚好遮住.点击时实际上点这一层.

确定

中国 美国 俄国 英国 法国 德国

亚洲 北美 东欧 西欧 地中海 波罗地海

雪地 极光 白马 拿破仑 元首 角斗士

当前手机视口

原文地址:https://www.cnblogs.com/mirrortom/p/10790470.html

时间: 2024-11-12 16:56:07

js手机滑块模仿的相关文章

js手机相应式多级导航分享

js手机相应导航,可以在自适应屏幕的时候运用,当网站屏幕小到一定程度是,让该导航出现,该导航效果如下图:多级导航! 主要的设计思路是:在菜单中往往会有很多内容或者有多个层次的子菜单,为了更加简洁和节省空间,在这个下拉菜单中将每个子菜单都隐藏在一个主导航按钮下方,当点击的时候通过细微的动画显示出来:当再次点击层级菜单时,可以再次以不同形式的动画展示下一级菜单.因为此菜单是流体布局的,所以可以很容易的适应于响应式布局当中. html代码: <div id="dl-menu" clas

HTML5+JS手机web开发之jQuery Mobile初涉

一.起始之语 我一直都是在PC上折腾网页的,这会儿怎么风向周边捣鼓起手机网页开发呢?原因是公司原先使用Java开发的产品,耗了不少人力财力,但是最后的效果却不怎么好.因为,Android系统一套东西,iPhone又是新的一套,折腾死人呐. 于是总监发狠,让我把手上的活都交出去,专心折腾web版的,看看最后效果如何. 加上我觊觎手机上的开发学习很久了,于是,一拍即合,搞起了手机开发方面的学习. 分享是很好的提高自身学习的方法.因为分享过程中梳理了所学,往往会有些意想不到的心得与收获.如此利人利已的

js手机联动选择地区仿ios 开源git

js手机联动选择地区 前言:由于网上找到了一个mobiscrool,比较全,但是不开源,只能试用15天,正式版竟然要三千块钱,穷人只能自己动手,写了个只针对弹窗地区选择的. 本站点所有的资源均在github上可以查看源代码 GitHub demo地址请点击这里 http://www.lovewebgames.com/jsmodule/mobile-select-area.html mobile-select-area 手机联动选择地区 用法 ##注:依赖于[dialog](https://git

JS 手机摇动

var SHAKE_THRESHOLD = 800;//摇动强度 var lastUpdate = 0; var x, y, z, last_x, last_y, last_z; var canshake = false; function deviceMotionHandler(eventData) { var acceleration = eventData.accelerationIncludingGravity; var curTime = new Date().getTime(); i

[js开源组件开发]js手机联动选择日期 开源git

js手机联动选择日期 这里在前面的<js手机联动选择地区>的基础上,改造数据源之后形成的一个日期的选择器,当然你可以使用之前的PC上模式的<日期控件>,它同时也支持手机端,http://www.cnblogs.com/tianxiangbing/p/calendar.html. 效果图如下: mobile-select-date 手机联动选择日期 这个组件是从mobile-select-area 继承过来的,所以调用方法基本相同 DEMO请点击这里  http://www.love

基于Node.js + jade + Mongoose 模仿gokk.tv

原文摘自我的前端博客,欢迎大家来访问 http://www.hacke2.cn 关于gokk 大学的娱乐活动基本就是在寝室看电影了→_→,一般都会选择去goxiazai.cc上看,里面的资源多,质量高 .站长会推荐评分很高广受好评的电影给大家免费下载,整体来说真是不错,但前两月由于版权问题被迫转型 这也是没办法的事,程序员更应该尊重版权问题,我们也能理解,后来站长又开了gokk个不是给地址让你 下载,而是将网络一些优秀视频站点资源提供出来观看,质量变低了,好怀念以前的goxiazai啊.. 最近

js手机触屏轮播效果

以前自己用纯js写的,找了N就都没找到,还是从同事哪里重新拿过来的,仅是备忘,看过新浪新闻的手机触屏端后,自己写了个效果,比新浪的省代码多了 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta http-equiv="Cache-Control&

js源码 模仿 jquery的ajax的获取数据(get,post )的请求封装

function ajax(obj){ // 默认参数 var defaults = { type : 'get', data : {}, url : '#', dataType : 'text', async : true, success : function(data){console.log(data)} } // 处理形参,传递参数的时候就覆盖默认参数,不传递就使用默认参数 for(var key in obj){//把输入的参数与设置的默认数据进行覆盖更新 defaults[key]

js手机站跳转

var yunzhuanhua_pc_domain = "http://www.域名.com#yht"; //PC站网址var yunzhuanhua_wap_domain = "http://m.域名.com#yht"; //手机站网址 document.writeln("<frameset cols=\"100%\"><frame src=\""+yunzhuanhua_pc_domain+&q