移动端滚动选择器mobileSelect.js
一款多功能的移动端滚动选择器,支持单选到多选、支持多级级联、提供自定义回调函数、提供update函数二次渲染、重定位函数、兼容pc端拖拽等等..
特性
- 原生js移动端选择控件,不依赖任何库
- 可传入普通数组或者json数组
- 可根据传入的参数长度,自动渲染出对应的列数,支持单项到多项选择
- 自动识别是否级联
- 选择成功后,提供自定义回调函数callback() 返回当前选择索引位置、以及选择的数据(数组/json)
- 每次手势滑动结束后,也提供一个回调函数transitionEnd() 返回当前选择索引位置、以及选择的数据(数组/json)
- 能够在已经实例化控件后,提供update函数再次渲染,可用于异步获取数据或点击交互后需要改变所选数据的场景
- 提供重定位函数
- 可以回显(第二次进入页面时,可以显示历史选择的位置)
引入
方式一 标签引入:
- <link rel="stylesheet" type="text/css" href="css/mobileSelect.css">
- <script src="js/mobileSelect.js" type="text/javascript"></script>
方式二 npm:
- npm install mobile-select -D
在你的js文件中import:
- import MobileSelect from 'mobile-select'
快速使用
①普通数组格式-非联动
- <div id="trigger1"></div> <!--页面中别漏了这个trigger-->
- <script type="text/javascript">
- var mobileSelect1 = new MobileSelect({
- trigger: '#trigger1',
- title: '单项选择',
- wheels: [
- {data:['周日','周一','周二','周三','周四','周五','周六']}
- ],
- position:[2] //初始化定位
- });
- </script>
②json格式-非联动
- <div id="trigger2"></div>
- <script type="text/javascript">
- var mobileSelect2 = new MobileSelect({
- trigger: '#trigger2',
- title: '地区选择',
- wheels: [
- {data:[
- {id:'1',value:'附近'},
- {id:'2',value:'上城区'},
- {id:'3',value:'下城区'},
- {id:'4',value:'江干区'},
- {id:'5',value:'拱墅区'},
- {id:'6',value:'西湖区'}
- ]},
- {data:[
- {id:'1',value:'1000米'},
- {id:'2',value:'2000米'},
- {id:'3',value:'3000米'},
- {id:'4',value:'5000米'},
- {id:'5',value:'10000米'}
- ]}
- ],
- callback:function(indexArr, data){
- console.log(data); //返回选中的json数据
- }
- });
- </script>
③json格式-联动
- <div id="trigger3"></div>
- <script type="text/javascript">
- var mobileSelect3 = new MobileSelect({
- trigger: '#trigger3',
- title: '地区选择-联动',
- wheels: [
- {data:[
- {
- id:'1',
- value:'附近',
- childs:[
- {id:'1',value:'1000米'},
- {id:'2',value:'2000米'},
- {id:'3',value:'3000米'},
- {id:'4',value:'5000米'},
- {id:'5',value:'10000米'}
- ]
- },
- {id:'2',value:'上城区'},
- {id:'3',value:'下城区'},
- {id:'4',value:'江干区'},
- {id:'5',value:'拱墅区'},
- {id:'6',value:'西湖区'}
- ]}
- ],
- position:[0,1],
- callback:function(indexArr, data){
- console.log(data); //返回选中的json数据
- }
- });
- </script>
④在vue-cli中如何使用
- npm install mobile-select -D
- <template>
- <div>
- <div id="trigger4">单项选择</div>
- </div>
- </template>
- <script>
- import MobileSelect from 'mobile-select'
- export default {
- mounted() {
- var mobileSelect4 = new MobileSelect({
- trigger: "#trigger4",
- title: "单项选择",
- wheels: [
- {data: ["周日","周一","周二","周三","周四","周五","周六"]}
- ],
- callback:function(indexArr, data){
- console.log(data);
- }
- });
- }
- }
- </script>
⑤数据字段名映射
- <div id="trigger5"></div>
- <script type="text/javascript">
- //假如你的数据的字段名为id,title,children
- //与mobileSelect的id,value,childs字段名不匹配
- //可以用keyMap属性进行字段名映射
- var mobileSelect5 = new MobileSelect({
- trigger: '#trigger5',
- title: '数据字段名映射',
- wheels: [
- {data:[
- {
- id:'1',
- title:'A',
- children:[
- {id:'A1',title:'A-a'},
- {id:'A2',title:'A-b'},
- {id:'A3',title:'A-c'}
- ]
- },
- {
- id:'1',
- title:'B',
- children:[
- {id:'B1',title:'B-a'},
- {id:'B2',title:'B-b'},
- {id:'B3',title:'B-c'}
- ]
- },
- ]}
- ],
- keyMap: {
- id:'id',
- value: 'title',
- childs :'children'
- },
- callback:function(indexArr, data){
- console.log(data);
- }
- });
- </script>
参数
选项 | 默认值 | 类型 | 描述 |
---|---|---|---|
trigger | 必填参数 无默认值 | String | 触发对象的id/class/tag |
wheels | 必填参数 无默认值 | Array | 数据源,需要显示的数据 |
callback | function(indexArr, data){} | function | 选择成功后触发的回调函数,返回indexArr、data |
transitionEnd | function(indexArr, data){} | function | 每一次手势滑动结束后触发的回调函数,返回indexArr、data |
cancel | function(indexArr, data){} | function | 返回的是indexArr和data是上一次点击确认按钮时的值 |
onShow | function(e){} | function | 显示控件后触发的回调函数, 返回参数为对象本身 |
onHide | function(e){} | function | 隐藏控件后触发的回调函数, 返回参数为对象本身 |
title | '' |
String | 控件标题 |
position | [0,0,0,…] | Array | 初始化定位 |
connector | ' ' |
String | 多个轮子时,多个值中间的连接符,默认是空格 |
ensureBtnText | '确认' |
String | 确认按钮的文本内容 |
cancelBtnText | '取消' |
String | 取消按钮的文本内容 |
ensureBtnColor | '#1e83d3' |
String | 确认按钮的文本颜色 |
cancelBtnColor | '#666666' |
String | 取消按钮的文本颜色 |
titleColor | '#000000' |
String | 控件标题的文本颜色 |
titleBgColor | '#ffffff' |
String | 控件标题的背景颜色 |
textColor | '#000000' |
String | 轮子内文本的颜色 |
bgColor | '#ffffff' |
String | 轮子背景颜色 |
maskOpacity | 0.7 |
Number | 遮罩透明度 |
keyMap | {id:'id', value:'value', childs:'childs' } |
Object | 字段名映射,适用于字段名不匹配id,value,childs的数据格式 |
triggerDisplayData | true |
Boolean | 在点击确认时,trigger的innerHtml是否变为选择的数据。 (如果trigger里面还有其他元素,则可以设置为false;如果需要在别的地方显示数据,则可用callback返回的数据自行拼接) |
注:回调函数中返回的参数含义如下
- indexArr是当前选中的索引数组 如[0,0,1] 代表有三个轮子 选中的数据是第一个轮子的第0个数据、第二个轮子的第0个数据、第三个轮子的第1个数据
- data是当前选中的json数据 如[{id:'1',value:'hello'},{id:'2',value:'world'}]
功能函数:
函数名 | 参数 | 描述 |
---|---|---|
show() | 无参 | 手动显示弹窗组件 |
hide() | 无参 | 手动隐藏弹窗组件 |
setTitle() | string | 设置控件的标题 |
locatePosition() | sliderIndex, posIndex | 传入位置数组,重新定位轮子选中的位置 |
updateWheel() | sliderIndex, data | 重新渲染指定的轮子 |
updateWheels() | data | 重新渲染所有轮子(仅限级联数据格式使用) |
getValue() | 无参 | 获取组件选择的值 |
注:功能函数中需要传递的参数含义如下
- sliderIndex 代表的是要修改的轮子的索引
- posIndex 代表位置索引
①功能函数demo:
- <div id="day"></div>
- var mySelect = new MobileSelect({
- trigger: '#day',
- wheels: [
- {data:['周日','周一','周二','周三','周四','周五','周六']},
- {data:['08:00','09:00','10:00','11:00','12:00','13:00','14:00']}
- ],
- position:[1,1] //初始化定位 两个轮子都选中在索引1的选项
- });
- //----------------------------------------------
- //进行基础的实例化之后,对实例用功能函数操作
- // mySelect.setTitle('啦啦啦(๑•̀ㅁ•́ฅ)');
- // 设置控件的标题
- // mySelect.updateWheel(0,['sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday']);
- // 更新第0个轮子的数据,数据变为英文的星期几
- // mySelect.locatePosition(1,0);
- // 重新定位第1个轮子的位置,将第1个轮子的第0个数据改为当前选中。
- // (第1个轮子是指右边的轮子,左边的轮子是第0个)
②ajax异步填充数据demo
- <!-- ************ 非级联格式 ************ -->
- <div id="trigger6"></div>
- <script type="text/javascript">
- var mobileSelect6 = new MobileSelect({
- trigger: '#trigger6',
- title: 'ajax填充数据-非级联',
- wheels: [
- {data:[
- {id:'1',value:'请选择地区'},
- ]},
- {data:[
- {id:'1',value:'请选择距离'},
- ]}
- ],
- callback:function(indexArr, data){
- console.log(data);
- }
- });
- $.ajax({
- type: "POST",
- url: "xxxx",
- data: {},
- dataType: "json",
- success: function(res){
- //这里假设获取到的res.data.area为:
- // [
- // {id:'1',value:'附近'},
- // {id:'2',value:'福田区'},
- // {id:'3',value:'罗湖区'},
- // {id:'4',value:'南山区'}
- // ]
- //这里假设获取到的res.data.distance为:
- // [
- // {id:'1',value:'200米'},
- // {id:'2',value:'300米'},
- // {id:'3',value:'400米'}
- // ]
- mobileSelect6.updateWheel(0, res.data.area); //更改第0个轮子
- mobileSelect6.updateWheel(1, res.data.distance); //更改第1个轮子
- }
- });
- </script>
- </script>
- <!-- ************ 级联格式 ************ -->
- <div id="trigger7"></div>
- <script type="text/javascript">
- var mobileSelect7 = new MobileSelect({
- trigger: '#trigger7',
- title: 'ajax填充数据-级联',
- wheels: [
- {data:[
- {
- id:'1',
- value:'',
- childs:[
- {id:'A1',value:''},
- ]
- }
- ]}
- ],
- callback:function(indexArr, data){
- console.log(data);
- }
- });
- $.ajax({
- type: "POST",
- url: "xxxx",
- data: {},
- dataType: "json",
- success: function(res){
- //这里假设获取到的res.data为:
- // [{
- // id:'1',
- // value:'更新后数据',
- // childs:[
- // {id:'A1',value:'apple'},
- // {id:'A2',value:'banana'},
- // {id:'A3',value:'orange'}
- // ]
- // }]
- mobileSelect7.updateWheels(res.data);
- }
- });
- </script>
如何回显选择的位置
callback回调函数里有一个indexArr参数,它是一个数组,记录着当前选中的位置:
把这个数组转化为字符串之后,可以用隐藏域或者别的其他方式保存下来,传给后台。
下次打开页面时,
MobileSelect实例化的时候,读取这个字符串,再转成数组,传给position,完成初始化定位即可。
git地址:
https://github.com/onlyhom/mobileSelect.js/blob/master/docs/README-CN.md
移动端滚动选择器mobileSelect.js的更多相关文章
- 一款多功能的移动端滚动选择器,支持单选到多选、支持多级级联、提供自定义回调函数、提供update函数二次渲染、重定位函数、兼容pc端拖拽等等..
https://github.com/onlyhom/mobileSelect.js/blob/master/docs/README-CN.md mobileSelect.js 一款多功能的移动端滚动 ...
- js手机移动端选择插件 mobileSelect.js
一.mobileSelect获取方法 mobileSelect支持单选.多级联动.自定义回调函数.二次渲染.最新版本下载地址[2017-09-21更新]: https://github.com/onl ...
- 手机端移动端的选择框mobileSelect.js使用
手机端移动端的选择框mobileSelect.js使用 文件地址:https://github.com/onlyhom/mobileSelect.js 请感兴趣的自行下载 使用过程 1 引入标签 &l ...
- 11-移动端开发教程-zepto.js入门教程
Zepto.js是一个轻量级的针对现代浏览器的JavaScript库, 它与jquery有着类似的api. 如果你会用jquery,那么你也会用zepto. 1. Why Zepto.js? API类 ...
- 微信小程序组件解读和分析:十二、picker滚动选择器
picker滚动选择器组件说明: picker: 滚动选择器,现支持三种选择器,通过mode属性来区分, 分别是普通选择器(mode = selector),时间选择器(mode = time),日期 ...
- 通通玩blend美工(6)下——仿iPhone滚动选择器的ListBox(交互逻辑)
原文:通通玩blend美工(6)下--仿iPhone滚动选择器的ListBox(交互逻辑) 上一篇我们已经把界面画出来了,这篇我们就来制作交互的逻辑吧.上一篇的电梯: http://www.cnblo ...
- react基础学习和react服务端渲染框架next.js踩坑
说明 React作为Facebook 内部开发 Instagram 的项目中,是一个用来构建用户界面的优秀 JS 库,于 2013 年 5 月开源.作为前端的三大框架之一,React的应用可以说是非常 ...
- Android PickerView滚动选择器的使用方法
手机里设置闹钟需要选择时间,那个选择时间的控件就是滚动选择器,前几天用手机刷了MIUI,发现自带的那个时间选择器效果挺好看的,于是就自己仿写了一个,权当练手.先来看效果: 效果还行吧?实现思路就是自定 ...
- Android自定义控件实战——滚动选择器PickerView
转载请声明出处http://blog.csdn.net/zhongkejingwang/article/details/38513301 手机里设置闹钟需要选择时间,那个选择时间的控件就是滚动选择器, ...
随机推荐
- iOS - 小功能 跳转到淘宝或天猫的商品展示详情页
最近做iOS项目的时候遇到一个需求,点击广告页,跳转到淘宝或天猫的商品详情页. 具体需要是这样: 1)安装了淘宝:跳转到淘宝详情页. 2)没装淘宝,装了天猫:跳转到天猫详情页 3)淘宝.天猫都没装:跳 ...
- tp框架防止表单重复提交
转载 框架官方 http://www.thinkphp.cn/topic/9090.html 第三方 https://my.oschina.net/caomenglong/blog/728908
- 将Centos7的yum配置为阿里云的镜像(完美解决yum下载太慢的问题)
2017-02-17 16:02:30 张老湿 阅读数 13768 http://mirrors.aliyun.com/help/centos?spm=5176.bbsr150321.0.0. ...
- Java抽象语法树AST,JCTree 分析
JCTree简要分析文章目录JCTree简要分析JCAnnotatedTypeJCAnnotationJCArrayAccessJCArrayTypeTreeJCAssertJCAssignJCAss ...
- openstack各服务端口使用情况
端口占用情况 端口情况可以使用ss -tanp命令进行查看 监听的所有端口ss -tanp | grep LISTEN 基础服务 22 --SSH 3306 --MariaDB(MySQL) 2701 ...
- python的简介(解释器、变量、用户交互、if语句)
一.python的起源 python是吉多·范罗苏姆(Guido van Rossum)在1989年的圣诞节期间因为无聊打发时间所开发的一个脚本解释程序. python是一门解释型.弱类型的编程语言. ...
- DevExpress中实现GridControl的分页功能
DevExpress中如何实现GridControl的分页功能 简介:DevExpress中如何实现GridControl的分页功能, 主要是利用DataNavigator和GridControl组合 ...
- Python 过滤a文件中每一行内容,保存到b文件中
#coding=utf-8print 1#初始化文件crash_log.log with open('e:/1/crash_log.log','w')as f: f.close() def fw(se ...
- MySQL 索引原理及慢查询优化
MySQL凭借着出色的性能.低廉的成本.丰富的资源,已经成为绝大多数互联网公司的首选关系型数据库.虽然性能出色,但所谓“好马配好鞍”,如何能够更好的使用它,已经成为开发工程师的必修课,我们经常会从职位 ...
- Go语言 - 关于常用插件不能安装的处理办法
解决办法 这里的是Windows的环境下的解决办法 在GOPATH的src目录下面创建github.com\golang文件夹,若文件夹存请忽略本步骤 在vs code终端执行: cd %GOPATH ...