一款多功能的移动端滚动选择器,支持单选到多选、支持多级级联、提供自定义回调函数、提供update函数二次渲染、重定位函数、兼容pc端拖拽等等..

特性

  • 原生js移动端选择控件,不依赖任何库
  • 可传入普通数组或者json数组
  • 可根据传入的参数长度,自动渲染出对应的列数,支持单项到多项选择
  • 自动识别是否级联
  • 选择成功后,提供自定义回调函数callback() 返回当前选择索引位置、以及选择的数据(数组/json)
  • 每次手势滑动结束后,也提供一个回调函数transitionEnd() 返回当前选择索引位置、以及选择的数据(数组/json)
  • 能够在已经实例化控件后,提供update函数再次渲染,可用于异步获取数据或点击交互后需要改变所选数据的场景
  • 提供重定位函数
  • 可以回显(第二次进入页面时,可以显示历史选择的位置)

引入

方式一 标签引入:

  1. <link rel="stylesheet" type="text/css" href="css/mobileSelect.css">
  2. <script src="js/mobileSelect.js" type="text/javascript"></script>

方式二 npm:

  1. npm install mobile-select -D

在你的js文件中import:

  1. import MobileSelect from 'mobile-select'

快速使用

①普通数组格式-非联动

  1. <div id="trigger1"></div> <!--页面中别漏了这个trigger-->
  2.  
  3. <script type="text/javascript">
  4. var mobileSelect1 = new MobileSelect({
  5. trigger: '#trigger1',
  6. title: '单项选择',
  7. wheels: [
  8. {data:['周日','周一','周二','周三','周四','周五','周六']}
  9. ],
  10. position:[2] //初始化定位
  11. });
  12. </script>

②json格式-非联动

  1. <div id="trigger2"></div>
  2.  
  3. <script type="text/javascript">
  4. var mobileSelect2 = new MobileSelect({
  5. trigger: '#trigger2',
  6. title: '地区选择',
  7. wheels: [
  8. {data:[
  9. {id:'1',value:'附近'},
  10. {id:'2',value:'上城区'},
  11. {id:'3',value:'下城区'},
  12. {id:'4',value:'江干区'},
  13. {id:'5',value:'拱墅区'},
  14. {id:'6',value:'西湖区'}
  15. ]},
  16. {data:[
  17. {id:'1',value:'1000米'},
  18. {id:'2',value:'2000米'},
  19. {id:'3',value:'3000米'},
  20. {id:'4',value:'5000米'},
  21. {id:'5',value:'10000米'}
  22. ]}
  23. ],
  24. callback:function(indexArr, data){
  25. console.log(data); //返回选中的json数据
  26. }
  27. });
  28. </script>

③json格式-联动

  1. <div id="trigger3"></div>
  2.  
  3. <script type="text/javascript">
  4. var mobileSelect3 = new MobileSelect({
  5. trigger: '#trigger3',
  6. title: '地区选择-联动',
  7. wheels: [
  8. {data:[
  9. {
  10. id:'1',
  11. value:'附近',
  12. childs:[
  13. {id:'1',value:'1000米'},
  14. {id:'2',value:'2000米'},
  15. {id:'3',value:'3000米'},
  16. {id:'4',value:'5000米'},
  17. {id:'5',value:'10000米'}
  18. ]
  19. },
  20. {id:'2',value:'上城区'},
  21. {id:'3',value:'下城区'},
  22. {id:'4',value:'江干区'},
  23. {id:'5',value:'拱墅区'},
  24. {id:'6',value:'西湖区'}
  25. ]}
  26. ],
  27. position:[0,1],
  28. callback:function(indexArr, data){
  29. console.log(data); //返回选中的json数据
  30. }
  31. });
  32. </script>

④在vue-cli中如何使用

  1. npm install mobile-select -D
  2. <template>
  3. <div>
  4. <div id="trigger4">单项选择</div>
  5. </div>
  6. </template>
  7.  
  8. <script>
  9. import MobileSelect from 'mobile-select'
  10.  
  11. export default {
  12. mounted() {
  13. var mobileSelect4 = new MobileSelect({
  14. trigger: "#trigger4",
  15. title: "单项选择",
  16. wheels: [
  17. {data: ["周日","周一","周二","周三","周四","周五","周六"]}
  18. ],
  19. callback:function(indexArr, data){
  20. console.log(data);
  21. }
  22. });
  23. }
  24. }
  25. </script>

⑤数据字段名映射

  1. <div id="trigger5"></div>
  2.  
  3. <script type="text/javascript">
  4. //假如你的数据的字段名为id,title,children
  5. //与mobileSelect的id,value,childs字段名不匹配
  6. //可以用keyMap属性进行字段名映射
  7. var mobileSelect5 = new MobileSelect({
  8. trigger: '#trigger5',
  9. title: '数据字段名映射',
  10. wheels: [
  11. {data:[
  12. {
  13. id:'1',
  14. title:'A',
  15. children:[
  16. {id:'A1',title:'A-a'},
  17. {id:'A2',title:'A-b'},
  18. {id:'A3',title:'A-c'}
  19. ]
  20. },
  21. {
  22. id:'1',
  23. title:'B',
  24. children:[
  25. {id:'B1',title:'B-a'},
  26. {id:'B2',title:'B-b'},
  27. {id:'B3',title:'B-c'}
  28. ]
  29. },
  30. ]}
  31. ],
  32. keyMap: {
  33. id:'id',
  34. value: 'title',
  35. childs :'children'
  36. },
  37. callback:function(indexArr, data){
  38. console.log(data);
  39. }
  40. });
  41. </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:

  1. <div id="day"></div>
  2.  
  3. var mySelect = new MobileSelect({
  4. trigger: '#day',
  5. wheels: [
  6. {data:['周日','周一','周二','周三','周四','周五','周六']},
  7. {data:['08:00','09:00','10:00','11:00','12:00','13:00','14:00']}
  8. ],
  9. position:[1,1] //初始化定位 两个轮子都选中在索引1的选项
  10. });
  11.  
  12. //----------------------------------------------
  13. //进行基础的实例化之后,对实例用功能函数操作
  14.  
  15. // mySelect.setTitle('啦啦啦(๑•̀ㅁ•́ฅ)');
  16. // 设置控件的标题
  17.  
  18. // mySelect.updateWheel(0,['sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday']);
  19. // 更新第0个轮子的数据,数据变为英文的星期几
  20.  
  21. // mySelect.locatePosition(1,0);
  22. // 重新定位第1个轮子的位置,将第1个轮子的第0个数据改为当前选中。
  23. // (第1个轮子是指右边的轮子,左边的轮子是第0个)

②ajax异步填充数据demo

  1. <!-- ************ 非级联格式 ************ -->
  2.  
  3. <div id="trigger6"></div>
  4.  
  5. <script type="text/javascript">
  6. var mobileSelect6 = new MobileSelect({
  7. trigger: '#trigger6',
  8. title: 'ajax填充数据-非级联',
  9. wheels: [
  10. {data:[
  11. {id:'1',value:'请选择地区'},
  12. ]},
  13. {data:[
  14. {id:'1',value:'请选择距离'},
  15. ]}
  16. ],
  17. callback:function(indexArr, data){
  18. console.log(data);
  19. }
  20. });
  21.  
  22. $.ajax({
  23. type: "POST",
  24. url: "xxxx",
  25. data: {},
  26. dataType: "json",
  27. success: function(res){
  28. //这里假设获取到的res.data.area为:
  29. // [
  30. // {id:'1',value:'附近'},
  31. // {id:'2',value:'福田区'},
  32. // {id:'3',value:'罗湖区'},
  33. // {id:'4',value:'南山区'}
  34. // ]
  35.  
  36. //这里假设获取到的res.data.distance为:
  37. // [
  38. // {id:'1',value:'200米'},
  39. // {id:'2',value:'300米'},
  40. // {id:'3',value:'400米'}
  41. // ]
  42.  
  43. mobileSelect6.updateWheel(0, res.data.area); //更改第0个轮子
  44. mobileSelect6.updateWheel(1, res.data.distance); //更改第1个轮子
  45. }
  46. });
  47. </script>
  48. </script>
  49.  
  50. <!-- ************ 级联格式 ************ -->
  51.  
  52. <div id="trigger7"></div>
  53.  
  54. <script type="text/javascript">
  55. var mobileSelect7 = new MobileSelect({
  56. trigger: '#trigger7',
  57. title: 'ajax填充数据-级联',
  58. wheels: [
  59. {data:[
  60. {
  61. id:'1',
  62. value:'',
  63. childs:[
  64. {id:'A1',value:''},
  65. ]
  66. }
  67. ]}
  68. ],
  69. callback:function(indexArr, data){
  70. console.log(data);
  71. }
  72. });
  73.  
  74. $.ajax({
  75. type: "POST",
  76. url: "xxxx",
  77. data: {},
  78. dataType: "json",
  79. success: function(res){
  80. //这里假设获取到的res.data为:
  81. // [{
  82. // id:'1',
  83. // value:'更新后数据',
  84. // childs:[
  85. // {id:'A1',value:'apple'},
  86. // {id:'A2',value:'banana'},
  87. // {id:'A3',value:'orange'}
  88. // ]
  89. // }]
  90. mobileSelect7.updateWheels(res.data);
  91. }
  92. });
  93. </script>

如何回显选择的位置

callback回调函数里有一个indexArr参数,它是一个数组,记录着当前选中的位置:
把这个数组转化为字符串之后,可以用隐藏域或者别的其他方式保存下来,传给后台。
下次打开页面时,
MobileSelect实例化的时候,读取这个字符串,再转成数组,传给position,完成初始化定位即可。

git地址:

https://github.com/onlyhom/mobileSelect.js/blob/master/docs/README-CN.md

移动端滚动选择器mobileSelect.js的更多相关文章

  1. 一款多功能的移动端滚动选择器,支持单选到多选、支持多级级联、提供自定义回调函数、提供update函数二次渲染、重定位函数、兼容pc端拖拽等等..

    https://github.com/onlyhom/mobileSelect.js/blob/master/docs/README-CN.md mobileSelect.js 一款多功能的移动端滚动 ...

  2. js手机移动端选择插件 mobileSelect.js

    一.mobileSelect获取方法 mobileSelect支持单选.多级联动.自定义回调函数.二次渲染.最新版本下载地址[2017-09-21更新]: https://github.com/onl ...

  3. 手机端移动端的选择框mobileSelect.js使用

    手机端移动端的选择框mobileSelect.js使用 文件地址:https://github.com/onlyhom/mobileSelect.js 请感兴趣的自行下载 使用过程 1 引入标签 &l ...

  4. 11-移动端开发教程-zepto.js入门教程

    Zepto.js是一个轻量级的针对现代浏览器的JavaScript库, 它与jquery有着类似的api. 如果你会用jquery,那么你也会用zepto. 1. Why Zepto.js? API类 ...

  5. 微信小程序组件解读和分析:十二、picker滚动选择器

    picker滚动选择器组件说明: picker: 滚动选择器,现支持三种选择器,通过mode属性来区分, 分别是普通选择器(mode = selector),时间选择器(mode = time),日期 ...

  6. 通通玩blend美工(6)下——仿iPhone滚动选择器的ListBox(交互逻辑)

    原文:通通玩blend美工(6)下--仿iPhone滚动选择器的ListBox(交互逻辑) 上一篇我们已经把界面画出来了,这篇我们就来制作交互的逻辑吧.上一篇的电梯: http://www.cnblo ...

  7. react基础学习和react服务端渲染框架next.js踩坑

    说明 React作为Facebook 内部开发 Instagram 的项目中,是一个用来构建用户界面的优秀 JS 库,于 2013 年 5 月开源.作为前端的三大框架之一,React的应用可以说是非常 ...

  8. Android PickerView滚动选择器的使用方法

    手机里设置闹钟需要选择时间,那个选择时间的控件就是滚动选择器,前几天用手机刷了MIUI,发现自带的那个时间选择器效果挺好看的,于是就自己仿写了一个,权当练手.先来看效果: 效果还行吧?实现思路就是自定 ...

  9. Android自定义控件实战——滚动选择器PickerView

    转载请声明出处http://blog.csdn.net/zhongkejingwang/article/details/38513301 手机里设置闹钟需要选择时间,那个选择时间的控件就是滚动选择器, ...

随机推荐

  1. iOS - 小功能 跳转到淘宝或天猫的商品展示详情页

    最近做iOS项目的时候遇到一个需求,点击广告页,跳转到淘宝或天猫的商品详情页. 具体需要是这样: 1)安装了淘宝:跳转到淘宝详情页. 2)没装淘宝,装了天猫:跳转到天猫详情页 3)淘宝.天猫都没装:跳 ...

  2. tp框架防止表单重复提交

    转载 框架官方 http://www.thinkphp.cn/topic/9090.html 第三方 https://my.oschina.net/caomenglong/blog/728908

  3. 将Centos7的yum配置为阿里云的镜像(完美解决yum下载太慢的问题)

    2017-02-17 16:02:30 张老湿 阅读数 13768     http://mirrors.aliyun.com/help/centos?spm=5176.bbsr150321.0.0. ...

  4. Java抽象语法树AST,JCTree 分析

    JCTree简要分析文章目录JCTree简要分析JCAnnotatedTypeJCAnnotationJCArrayAccessJCArrayTypeTreeJCAssertJCAssignJCAss ...

  5. openstack各服务端口使用情况

    端口占用情况 端口情况可以使用ss -tanp命令进行查看 监听的所有端口ss -tanp | grep LISTEN 基础服务 22 --SSH 3306 --MariaDB(MySQL) 2701 ...

  6. python的简介(解释器、变量、用户交互、if语句)

    一.python的起源 python是吉多·范罗苏姆(Guido van Rossum)在1989年的圣诞节期间因为无聊打发时间所开发的一个脚本解释程序. python是一门解释型.弱类型的编程语言. ...

  7. DevExpress中实现GridControl的分页功能

    DevExpress中如何实现GridControl的分页功能 简介:DevExpress中如何实现GridControl的分页功能, 主要是利用DataNavigator和GridControl组合 ...

  8. 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 ...

  9. MySQL 索引原理及慢查询优化

    MySQL凭借着出色的性能.低廉的成本.丰富的资源,已经成为绝大多数互联网公司的首选关系型数据库.虽然性能出色,但所谓“好马配好鞍”,如何能够更好的使用它,已经成为开发工程师的必修课,我们经常会从职位 ...

  10. Go语言 - 关于常用插件不能安装的处理办法

    解决办法 这里的是Windows的环境下的解决办法 在GOPATH的src目录下面创建github.com\golang文件夹,若文件夹存请忽略本步骤 在vs code终端执行: cd %GOPATH ...