做个简单实用的选择器,从此远离满世界找插件
发布时间:2016-07-19, 14:50:45 分类:默认分类 | 编辑 off 网址 | 辅助
图集1/6
正文 26042字数 104,476阅读
mobile-selector-master使用方法:在JS包的说明里;直接使用例子也是可以的
起因:一直以来,移动端选择器都是自己在网上满世界的找插件
缺点:
1.前期需要自己找非常多的插件,进行筛选;浪费了自己大量的时间
2.符合要求的少之又少,能最后用上的就更少了;
3.项目有特殊要求,又要符合设计稿,难上加难;
所以,这次自己写了一个选择器,来张图再说:
第一类:自定义单一选择器
第二类:独立两个选项选择器
第三类:年月日选择器
第四类:年月日+时间选择器
优点:
1.代码量非常少
2.非常的便于使用和理解
3.可变性非常高,理解思路自己就可以制作属于你的选择器
缺点:
封装的不是很好,这个是基于目前自己的整体水平,随着自己的学习和理解会渐渐的优化,让这个选择器越来越好
项目地址
HTML代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no">
<title>选择器</title>
</head>
<style>
body{margin:0;font-family:Gotham, "Helvetica Neue", Helvetica, Arial, sans-serif;background:#eee;}
</style>
<body>
<div style="margin-top:10px;">
<span style="padding-right:10px;">年份</span>
<input style="border:solid 1px red;" class="qu-year" type="text">
</div>
<div style="margin-top:10px;">
<span style="padding-right:10px;">身高</span>
<input style="border:solid 1px red;" class="qu-height" type="text">
</div>
<div style="margin-top:10px;">
<span style="padding-right:10px;">体重</span>
<input style="border:solid 1px red;" class="qu-weight" type="text">
</div>
<div style="margin-top:10px;">
<span style="padding-right:10px;">睡眠</span>
<input style="border:solid 1px red;" class="qu-time" type="text">
</div>
<div style="margin-top:10px;">
<span style="padding-right:10px;">年月日+时间</span>
<input style="border:solid 1px red;margin-top:10px" class="sp-date" type="text">
</div>
<div style="margin-top:10px;">
<span style="padding-right:10px;">年月日</span>
<input style="border:solid 1px red;margin-top:10px" class="sp-time" type="text">
</div>
<script src="js/jq.js"></script>
<script src="js/jquery.selector.js"></script>
<script>
$(function(){
// ---------【数据部分开始】---------
// 出生年份计算,当前年份-(当前年份-100)
var nowYear = new Date().getFullYear();
var gYear = [];
for(var i=0;i<100;i++){
gYear.push(Number(nowYear)-i);
};
// 身高范围,50-220
var quHeight = [50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220];
// 体重范围,20-220(整数),0-9(小数)
// 整数
var quWeightInt = [20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220];
// 小数
var quWeightFl = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
// 时长数据
// 小时
var spoHour = ["00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23"];
// 分钟
var spoMinute = ["00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "24", "25", "26", "27", "28", "29", "30", "31", "32", "33", "34", "35", "36", "37", "38", "39", "40", "41", "42", "43", "44", "45", "46", "47", "48", "49", "50", "51", "52", "53", "54", "55", "56", "57", "58", "59"];
// ---------【数据部分结束】---------
scrEvent(gYear,'.qu-year','出生年份',1980);
scrEvent(quHeight,'.qu-height','身高/cm',170);
scrEvent2(quWeightInt,'.qu-weight',"体重/kg",60,quWeightFl,0,'.','','');
scrEvent2(spoHour,'.qu-time',"睡眠时长",6,spoMinute,0,':','小时','分钟');
// 年月日
dateSelector('.sp-date',1990,12,08,'-',true,12,0);
dateSelector('.sp-time',1991,08,08,'-');
});
</script>
</body>
</html>
Run code
Cut to clipboard
jquery.selector.js
/*
* @Author: liufeifei
* @Date: 2016-07-16 11:45:10
* @Last Modified by: liufeifei
* @Last Modified time: 2016-07-18 17:58:19
* 总体说明:分为四种,第一种为单个选项选择,第二种为两个选项选择(两个选项之间独立存在),第三种为年月日选择,第四种为年月日+小时分钟选择
*/
// 'use strict';
// ---------【数据部分开始】例子---------
// 体重范围,20-220(整数),0-9(小数)
// 整数
// var quWeightInt = [20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220];
// 小数
// var quWeightFl = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
// ---------【数据部分结束】---------
// 选择器结构和样式封装
$('.sel-boxs').remove();
$('body').append('<style>'+
'.sel-boxs{display:none;}'+
'.sel-boxs .bg{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:998;}'+
'.sel-box{position:fixed;bottom:0;left:0;right:0;z-index:999;}'+
'.sel-box .btn{background:#fda626;overflow:hidden;}'+
'.sel-box .btn1{overflow:hidden;width:22px;height:22px;float:left;padding:11px 12px;}'+
'.sel-box .btn1 img{float:left;width:100%;height:100%;}'+
'.sel-box .ok{float:right;}'+
'.sel-box .name{color:white;text-align:center;line-height:22px;font-size:18px;padding:11px 0;}'+
'.sel-con{background:white;}'+
'.sel-con .border{height:34px;border:solid 1px #fda626;border-width:1px 0;position:fixed;bottom:72px;left:0;right:0;pointer-events:none;}'+
'.sel-con .table{display:table;width:100%;table-layout:fixed;}'+
'.sel-con .cell{display:table-cell;vertical-align:middle;text-align:center;overflow:hidden;}'+
'.sel-con .scroll{height:180px;overflow:auto;box-sizing:border-box;padding:72px 0;width:110%;padding-right:10%;}'+
'.sel-con .ele{font-size:16px;color:#b2b2b2;height:36px;line-height:36px;}'+
'</style>'+
'<div class="sel-boxs">'+
' <div class="bg"></div>'+
' <div class="sel-box">'+
' <div class="btn">'+
' <div class="btn1 ok"><img src="" alt="确定"></div>'+
' <div class="btn1 cancel"><img src="" alt="取消"></div>'+
' <div class="name">加载中...</div>'+
' </div>'+
' <div class="sel-con">'+
' <div class="border"></div>'+
' <div class="table"></div>'+
' </div>'+
' </div>'+
'</div>');
// 封装说明:
// 基于jQuery
// 适合场景,只适用于单个值的选取模式
// scrEvent(ele,evEle,selName,defValue)
// 1.参数【ele】是选择器取值范围,类型为数组
// 2.参数【evEle】是要绑定元素的元素名称,如:class、id、element...
// 3.参数【selName】是选择器名称
// 4.参数【defValue】是选择器默认值
function dataFrame(ele){
// ele数组转换成相应结构
var eleText = '';
for(var i=0;i<ele.length;i++){
eleText += '<div class="ele">'+ele[i]+'</div>';
};
return '<div class="cell elem"><div class="scroll">'+eleText+'</div></div>';
};
function scrEvent(ele,evEle,selName,defValue){
$(evEle).attr('readonly','readonly');
// 点击对应input执行事件
$(evEle).click(function(){
$('.sel-con .table').html(dataFrame(ele));
$('.sel-box .name').text(selName);
$('.sel-boxs').show();
// 默认值
$(evEle).val()==""?defValue = defValue:defValue=$(evEle).val();
$('.sel-con').find('.elem').eq(0).find('.ele').each(function(){
if($(this).text()==defValue){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
// 选择器滚动获取值和确认赋值
var scText = ele[0]; // 默认值为数组第一个值
$('.sel-con .scroll').scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
scText = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
// 确认选择
$('.sel-box .ok').click(function(){
$(evEle).val(scText);
$('.sel-boxs').hide();
});
});
};
// 封装说明:
// 基于jQuery
// 适合场景,只适用于两个值的选取模式
// scrEvent2(ele,evEle,selName,defValue,ele2)
// 1.参数【ele】是选择器取值范围,类型为数组
// 2.参数【evEle】是要绑定元素的元素名称,如:class、id、element...
// 3.参数【selName】是选择器名称
// 4.参数【defValue】是选择器第一个取值默认值
// 5.参数【ele2】是选择器取值范围第二个值,类型为数组
// 6.参数【defValue2】是选择器第二个取值默认值
// 7.参数【linkType】是第一个值和第二个值中间链接符号
// 8.参数【eleName】是选择器第一个值的名称,不需要应设置成空【''】
// 9.参数【eleName2】是选择器第二个值的名称,不需要应设置成空【''】
function scrEvent2(ele,evEle,selName,defValue,ele2,defValue2,linkType,eleName,eleName2){
$(evEle).attr('readonly','readonly');
eleName!=''?eleName = '<div class="cell" style="font-size:14px;color:#b2b2b2;">'+eleName+'</div>':eleName = '';
eleName2!=''?eleName2 = '<div class="cell" style="font-size:14px;color:#b2b2b2;">'+eleName2+'</div>':eleName2 = '';
// 点击对应input执行事件
$(evEle).click(function(){
$('.sel-con .table').html(dataFrame(ele)+eleName+dataFrame(ele2)+eleName2);
$('.sel-box .name').text(selName);
$('.sel-boxs').show();
// 第一个值默认值
$(evEle).val()==""?defValue = defValue:defValue=$(evEle).val().split(linkType)[0];
$(evEle).val()==""?defValue2 = defValue2:defValue2=$(evEle).val().split(linkType)[1];
$('.sel-con').find('.elem').eq(0).find('.ele').each(function(){
if($(this).text()==defValue){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
// 第二个值默认值
$('.sel-con').find('.elem').eq(1).find('.ele').each(function(){
if($(this).text()==defValue2){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
// 选择器滚动获取值和确认赋值
var scText = ele[0]; // 默认值为数组第一个值
var scText2 = ele2[0]; // 默认值为数组第二个值
$('.sel-con .scroll').scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
if($(this).parents('.elem').index()==0){
scText = $(this).find('.ele').eq(scNum).text();
}else{
scText2 = $(this).find('.ele').eq(scNum).text();
};
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
// 确认选择
$('.sel-box .ok').click(function(){
$(evEle).val(scText+linkType+scText2);
$('.sel-boxs').hide();
});
});
};
// 选择器
// 封装说明:
// 基于jQuery
// 适合场景,适用于年 月 日选择
// dateSelector(evEle,year,month,day)
// 1.参数【evEle】是要绑定元素的元素名称,如:class、id、element...
// 2.参数【year】默认显示年,没有需设置为空
// 3.参数【month】默认显示月,没有需设置为空
// 4.参数【day】默认显示日,没有需设置为空
// 5.参数【timeBoo】true:使用年月日+时间 false:使用年月日
// 6.参数【hour】默认显示小时
// 7.参数【minute】默认显示分钟
// 每个月的天数
function getMonthDays(year,month){
return new Date(year,month,0).getDate();
};
// 天数小于10天在前面加"0"
function twoZero(n){
return n<10?n='0'+n:n=n+'';
};
// 天数转换成数组
function couDay(n){
arrDay = [];
for(var i=1;i<=n;i++){
arrDay.push(twoZero(i));
};
return arrDay;
};
function dateSelector(evEle,year,month,day,linkType,timeBoo,hour,minute){
$(evEle).attr('readonly','readonly');
// 年 范围:当前年份 ~ 当前年份-99
var hunYear = [];
for(var i=0;i<100;i++){
hunYear.push(new Date().getFullYear()-i)
};
// 月 范围:十二个月份
var tweMonth = ['01','02','03','04','05','06','07','08','09','10','11','12'];
// 日 获取日期
var arrDay = [];
// 小时
var timeHour = ["00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23"];
// 分钟
var timeMinute = ["00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "24", "25", "26", "27", "28", "29", "30", "31", "32", "33", "34", "35", "36", "37", "38", "39", "40", "41", "42", "43", "44", "45", "46", "47", "48", "49", "50", "51", "52", "53", "54", "55", "56", "57", "58", "59"];
// year month day空处理
year==''?year=hunYear[0]:year=year;
month==''?month=tweMonth[0]:month=month;
day==''?day="01":day=day;
hour==''||hour==undefined?hour=timeHour[0]:hour=hour;
minute==''||minute==undefined?minute=timeMinute[0]:minute=minute;
// 年月日选择器
$(evEle).click(function(){
var timeGroup = '';
if(timeBoo){
timeGroup=dataFrame(timeHour)+dataFrame(timeMinute);
};
$('.sel-con .table').html(dataFrame(hunYear)+dataFrame(tweMonth)+dataFrame(couDay(getMonthDays(hunYear[0],tweMonth[0])))+timeGroup);
$('.sel-box .name').text("日期选择");
$('.sel-boxs').show();
// 选择器
if($(evEle).val()!=''){
year = $(evEle).val().split(linkType)[0]
month = $(evEle).val().split(linkType)[1]
day = $(evEle).val().split(linkType)[2]
if(timeBoo){
day = $(evEle).val().split(linkType)[2].split(' ')[0];
hour = $(evEle).val().split(linkType)[2].split(' ')[1].split(':')[0];
minute = $(evEle).val().split(linkType)[2].split(' ')[1].split(':')[1];
};
};
var scText = year; // 年
var scText2 = month; // 月
var scText3 = day; // 日
var scText4 = hour; // 小时
var scText5 = minute; // 分钟
$('.sel-con').find('.elem').eq(0).find('.ele').each(function(){
if($(this).text()==year){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
$('.sel-con').find('.elem').eq(1).find('.ele').each(function(){
if($(this).text()==month){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
$('.sel-con').find('.elem').eq(2).find('.ele').each(function(){
if($(this).text()==day){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
if(timeBoo){
$('.sel-con').find('.elem').eq(3).find('.ele').each(function(){
if($(this).text()==hour){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
$('.sel-con').find('.elem').eq(4).find('.ele').each(function(){
if($(this).text()==minute){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
};
$('.sel-con .scroll').eq(0).scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
scText = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
$('.sel-con .table').find('.elem').eq(2).remove();
$('.sel-con .table').find('.elem').eq(1).after(dataFrame(couDay(getMonthDays(scText,scText2))));
// 固定在原来的值
$('.sel-con').find('.elem').eq(2).find('.ele').each(function(){
if(Number($(this).text())<=Number(scText3)){
$(this).parents('.scroll').scrollTop($(this).index()*36);
}
});
$('.sel-con .scroll').eq(2).scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
scText3 = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
});
$('.sel-con .scroll').eq(1).scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
scText2 = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
$('.sel-con .table').find('.elem').eq(2).remove();
$('.sel-con .table').find('.elem').eq(1).after(dataFrame(couDay(getMonthDays(scText,scText2))));
// 固定在原来的值
$('.sel-con').find('.elem').eq(2).find('.ele').each(function(){
if(Number($(this).text())<=Number(scText3)){
$(this).parents('.scroll').scrollTop($(this).index()*36);
};
});
$('.sel-con .scroll').eq(2).scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
scText3 = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
});
$('.sel-con .scroll').eq(2).scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
scText3 = $(this).find('.ele').eq(scNum).text();
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
var time = '';
if(timeBoo){
$('.sel-con .scroll').scroll(function(){
var that = $(this);
// 数值显示
var scTop = $(this).scrollTop()+18;
var scNum = Math.floor(scTop/36);
// 类型名称
if($(this).parents('.elem').index()==3){
scText4 = $(this).find('.ele').eq(scNum).text();
}else if($(this).parents('.elem').index()==4){
scText5 = $(this).find('.ele').eq(scNum).text();
};
time = ' '+scText4+':'+scText5
// 停止锁定
clearTimeout($(this).attr('timer'));
$(this).attr('timer',setTimeout(function(){that.scrollTop(scNum*36);},100));
});
};
// 进行传值
$('.sel-box .ok').click(function(){
$(evEle).val(scText+linkType+scText2+linkType+scText3+time);
$('.sel-boxs').hide();
});
});
};
// 取消选择
$('.sel-box .cancel,.sel-boxs .bg').click(function(){
$('.sel-boxs').hide();
});
Run code
Cut to clipboard
# mobile-selector
移动端选择器=>总体说明:分为四种,第一种为单个选项选择,第二种为两个选项选择(两个选项之间独立存在),第三种为年月日选择,第四种为年月日+小时分钟选择
Run code
Cut to clipboard
源码打包下载:附件:upload/attach/tbs-J6NW0TBcI9.rar
(支付宝)给作者钱财以资鼓励 (微信)→
暂无评论 »