wheel.html 250 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <title>wheel | BetterScroll 2.0</title>
  7. <meta name="generator" content="VuePress 1.9.10">
  8. <link rel="shortcut icon" href="/docs/assets/bs.ico" type="images/x-icon">
  9. <script src="https://www.googletagmanager.com/gtag/js?id=G-7E85TW7P27"></script>
  10. <script type="text/javascript">
  11. window.dataLayer = window.dataLayer || [];
  12. function gtag(){dataLayer.push(arguments);}
  13. gtag('js', new Date());
  14. gtag('config', 'G-7E85TW7P27');
  15. </script>
  16. <meta name="description" content="Make Scroll Perfect">
  17. <link rel="preload" href="/docs/assets/css/0.styles.0cd93813.css" as="style"><link rel="preload" href="/docs/assets/js/app.c71b64d3.js" as="script"><link rel="preload" href="/docs/assets/js/5.d6412664.js" as="script"><link rel="preload" href="/docs/assets/js/4.4855b9ef.js" as="script"><link rel="preload" href="/docs/assets/js/3.481632b4.js" as="script"><link rel="preload" href="/docs/assets/js/121.e41f8100.js" as="script"><link rel="preload" href="/docs/assets/js/56.cd04bae9.js" as="script"><link rel="preload" href="/docs/assets/js/7.518ccda7.js" as="script"><link rel="prefetch" href="/docs/assets/js/1.8644db92.js"><link rel="prefetch" href="/docs/assets/js/10.6f8c38eb.js"><link rel="prefetch" href="/docs/assets/js/100.ee08226e.js"><link rel="prefetch" href="/docs/assets/js/101.fd2f3d9f.js"><link rel="prefetch" href="/docs/assets/js/102.79d86e3d.js"><link rel="prefetch" href="/docs/assets/js/103.7a3ae3b5.js"><link rel="prefetch" href="/docs/assets/js/104.7be4589d.js"><link rel="prefetch" href="/docs/assets/js/105.75386d15.js"><link rel="prefetch" href="/docs/assets/js/106.a4a18e8d.js"><link rel="prefetch" href="/docs/assets/js/107.561ec2e2.js"><link rel="prefetch" href="/docs/assets/js/108.1c61689f.js"><link rel="prefetch" href="/docs/assets/js/109.da71a73e.js"><link rel="prefetch" href="/docs/assets/js/110.5e0fa2d1.js"><link rel="prefetch" href="/docs/assets/js/111.1e326dd1.js"><link rel="prefetch" href="/docs/assets/js/112.590ba317.js"><link rel="prefetch" href="/docs/assets/js/113.cf201ace.js"><link rel="prefetch" href="/docs/assets/js/114.6d895ce2.js"><link rel="prefetch" href="/docs/assets/js/115.572aee19.js"><link rel="prefetch" href="/docs/assets/js/116.754722a0.js"><link rel="prefetch" href="/docs/assets/js/117.15e4dab3.js"><link rel="prefetch" href="/docs/assets/js/118.721d68f8.js"><link rel="prefetch" href="/docs/assets/js/119.c5c28d96.js"><link rel="prefetch" href="/docs/assets/js/120.12cd2e0e.js"><link rel="prefetch" href="/docs/assets/js/122.9ebe2f53.js"><link rel="prefetch" href="/docs/assets/js/123.f90c91f9.js"><link rel="prefetch" href="/docs/assets/js/13.b0c40cd7.js"><link rel="prefetch" href="/docs/assets/js/14.28bec126.js"><link rel="prefetch" href="/docs/assets/js/15.87b22af4.js"><link rel="prefetch" href="/docs/assets/js/16.c10e14e7.js"><link rel="prefetch" href="/docs/assets/js/17.5c921c77.js"><link rel="prefetch" href="/docs/assets/js/18.dc23b7e3.js"><link rel="prefetch" href="/docs/assets/js/19.a4034f95.js"><link rel="prefetch" href="/docs/assets/js/2.03f0f2c8.js"><link rel="prefetch" href="/docs/assets/js/20.8633fd45.js"><link rel="prefetch" href="/docs/assets/js/21.1fbf8d7e.js"><link rel="prefetch" href="/docs/assets/js/22.2888cfc5.js"><link rel="prefetch" href="/docs/assets/js/23.f951d302.js"><link rel="prefetch" href="/docs/assets/js/24.12842718.js"><link rel="prefetch" href="/docs/assets/js/25.5a5a3137.js"><link rel="prefetch" href="/docs/assets/js/26.88e81f0b.js"><link rel="prefetch" href="/docs/assets/js/27.152b8fda.js"><link rel="prefetch" href="/docs/assets/js/28.22550ea8.js"><link rel="prefetch" href="/docs/assets/js/29.f43fa807.js"><link rel="prefetch" href="/docs/assets/js/30.4ed38f67.js"><link rel="prefetch" href="/docs/assets/js/31.af4018f6.js"><link rel="prefetch" href="/docs/assets/js/32.930ee0b7.js"><link rel="prefetch" href="/docs/assets/js/33.c6a68c75.js"><link rel="prefetch" href="/docs/assets/js/34.6d10da1e.js"><link rel="prefetch" href="/docs/assets/js/35.11ba7b51.js"><link rel="prefetch" href="/docs/assets/js/36.8a54712b.js"><link rel="prefetch" href="/docs/assets/js/37.b26eb85d.js"><link rel="prefetch" href="/docs/assets/js/38.d6569a11.js"><link rel="prefetch" href="/docs/assets/js/39.1d22cfba.js"><link rel="prefetch" href="/docs/assets/js/40.577a94d7.js"><link rel="prefetch" href="/docs/assets/js/41.155e01e0.js"><link rel="prefetch" href="/docs/assets/js/42.3c26eaba.js"><link rel="prefetch" href="/docs/assets/js/43.d90991e2.js"><link rel="prefetch" href="/docs/assets/js/44.5437344c.js"><link rel="prefetch" href="/docs/assets/js/45.0d2eca0a.js"><link rel="prefetch" href="/docs/assets/js/46.11455b40.js"><link rel="prefetch" href="/docs/assets/js/47.1ee1a8f0.js"><link rel="prefetch" href="/docs/assets/js/48.c82450ab.js"><link rel="prefetch" href="/docs/assets/js/49.8016ee5f.js"><link rel="prefetch" href="/docs/assets/js/50.ab73e091.js"><link rel="prefetch" href="/docs/assets/js/51.bce6eb99.js"><link rel="prefetch" href="/docs/assets/js/52.c9b1992f.js"><link rel="prefetch" href="/docs/assets/js/53.7057f0f5.js"><link rel="prefetch" href="/docs/assets/js/54.cbb0a6b5.js"><link rel="prefetch" href="/docs/assets/js/55.89176a68.js"><link rel="prefetch" href="/docs/assets/js/57.c7a42e07.js"><link rel="prefetch" href="/docs/assets/js/58.09d6cb1b.js"><link rel="prefetch" href="/docs/assets/js/59.8445a09f.js"><link rel="prefetch" href="/docs/assets/js/6.5737c458.js"><link rel="prefetch" href="/docs/assets/js/60.86b1f417.js"><link rel="prefetch" href="/docs/assets/js/61.fa371ad1.js"><link rel="prefetch" href="/docs/assets/js/62.dbc75ddc.js"><link rel="prefetch" href="/docs/assets/js/63.a4465c93.js"><link rel="prefetch" href="/docs/assets/js/64.a39c3193.js"><link rel="prefetch" href="/docs/assets/js/65.a7275f82.js"><link rel="prefetch" href="/docs/assets/js/66.afd0af7d.js"><link rel="prefetch" href="/docs/assets/js/67.8009e00e.js"><link rel="prefetch" href="/docs/assets/js/68.de3c51dd.js"><link rel="prefetch" href="/docs/assets/js/69.41a50235.js"><link rel="prefetch" href="/docs/assets/js/70.938e9532.js"><link rel="prefetch" href="/docs/assets/js/71.af7fca59.js"><link rel="prefetch" href="/docs/assets/js/72.25df569a.js"><link rel="prefetch" href="/docs/assets/js/73.f16b7dc3.js"><link rel="prefetch" href="/docs/assets/js/74.d2184ed7.js"><link rel="prefetch" href="/docs/assets/js/75.9497b6fa.js"><link rel="prefetch" href="/docs/assets/js/76.2081d35e.js"><link rel="prefetch" href="/docs/assets/js/77.e5a8b470.js"><link rel="prefetch" href="/docs/assets/js/78.6d3ef23b.js"><link rel="prefetch" href="/docs/assets/js/79.025583e1.js"><link rel="prefetch" href="/docs/assets/js/8.8547d4ad.js"><link rel="prefetch" href="/docs/assets/js/80.e7e3ef35.js"><link rel="prefetch" href="/docs/assets/js/81.569d569f.js"><link rel="prefetch" href="/docs/assets/js/82.ac3ed0f7.js"><link rel="prefetch" href="/docs/assets/js/83.3393dfc3.js"><link rel="prefetch" href="/docs/assets/js/84.e5352ac1.js"><link rel="prefetch" href="/docs/assets/js/85.c7cdb129.js"><link rel="prefetch" href="/docs/assets/js/86.0aa0af94.js"><link rel="prefetch" href="/docs/assets/js/87.0db12b1e.js"><link rel="prefetch" href="/docs/assets/js/88.e8651cfa.js"><link rel="prefetch" href="/docs/assets/js/89.1b58abde.js"><link rel="prefetch" href="/docs/assets/js/9.0a882dfc.js"><link rel="prefetch" href="/docs/assets/js/90.d65d2d13.js"><link rel="prefetch" href="/docs/assets/js/91.32b2ad41.js"><link rel="prefetch" href="/docs/assets/js/92.795675a1.js"><link rel="prefetch" href="/docs/assets/js/93.818e5569.js"><link rel="prefetch" href="/docs/assets/js/94.79c2b16e.js"><link rel="prefetch" href="/docs/assets/js/95.4810ee5e.js"><link rel="prefetch" href="/docs/assets/js/96.6e382fd5.js"><link rel="prefetch" href="/docs/assets/js/97.e270d7b5.js"><link rel="prefetch" href="/docs/assets/js/98.728ef6c2.js"><link rel="prefetch" href="/docs/assets/js/99.c75096e0.js"><link rel="prefetch" href="/docs/assets/js/vendors~docsearch.2091e099.js">
  18. <link rel="stylesheet" href="/docs/assets/css/0.styles.0cd93813.css">
  19. </head>
  20. <body>
  21. <div id="app" data-server-rendered="true"><div class="theme-container"><header class="navbar"><div class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/docs/zh-CN/" class="home-link router-link-active"><img src="https://dpubstatic.udache.com/static/dpubimg/t_L6vAgQ-E/logo.svg" alt="BetterScroll 2.0" class="logo"> <span class="site-name can-hide">BetterScroll 2.0</span></a> <div class="links"><form id="search-form" role="search" class="algolia-search-wrapper search-box"><input id="algolia-search-input" class="search-query"></form> <nav class="nav-links can-hide"><div class="nav-item"><a href="/docs/zh-CN/guide/" class="nav-link">
  22. 指南
  23. </a></div><div class="nav-item"><a href="/docs/zh-CN/plugins/" class="nav-link router-link-active">
  24. 插件
  25. </a></div><div class="nav-item"><a href="/docs/zh-CN/FAQ/" class="nav-link">
  26. 常见问题
  27. </a></div><div class="nav-item"><a href="https://github.com/ustbhuangyi/better-scroll/issues" target="_blank" rel="noopener noreferrer" class="nav-link external">
  28. 讨论
  29. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="Select language" class="dropdown-title"><span class="title">选择语言</span> <span class="arrow down"></span></button> <button type="button" aria-label="Select language" class="mobile-dropdown-title"><span class="title">选择语言</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/docs/en-US/plugins/wheel.html" class="nav-link">
  30. English
  31. </a></li><li class="dropdown-item"><!----> <a href="/docs/zh-CN/plugins/wheel.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">
  32. 简体中文
  33. </a></li></ul></div></div> <a href="https://github.com/ustbhuangyi/better-scroll" target="_blank" rel="noopener noreferrer" class="repo-link">
  34. GitHub
  35. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav></div></header> <div class="sidebar-mask"></div> <aside class="sidebar"><nav class="nav-links"><div class="nav-item"><a href="/docs/zh-CN/guide/" class="nav-link">
  36. 指南
  37. </a></div><div class="nav-item"><a href="/docs/zh-CN/plugins/" class="nav-link router-link-active">
  38. 插件
  39. </a></div><div class="nav-item"><a href="/docs/zh-CN/FAQ/" class="nav-link">
  40. 常见问题
  41. </a></div><div class="nav-item"><a href="https://github.com/ustbhuangyi/better-scroll/issues" target="_blank" rel="noopener noreferrer" class="nav-link external">
  42. 讨论
  43. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="Select language" class="dropdown-title"><span class="title">选择语言</span> <span class="arrow down"></span></button> <button type="button" aria-label="Select language" class="mobile-dropdown-title"><span class="title">选择语言</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/docs/en-US/plugins/wheel.html" class="nav-link">
  44. English
  45. </a></li><li class="dropdown-item"><!----> <a href="/docs/zh-CN/plugins/wheel.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">
  46. 简体中文
  47. </a></li></ul></div></div> <a href="https://github.com/ustbhuangyi/better-scroll" target="_blank" rel="noopener noreferrer" class="repo-link">
  48. GitHub
  49. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav> <ul class="sidebar-links"><li><section class="sidebar-group depth-0"><p class="sidebar-heading"><span></span> <!----></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/docs/zh-CN/plugins/" aria-current="page" class="sidebar-link">插件</a></li><li><a href="/docs/zh-CN/plugins/how-to-write.html" class="sidebar-link">如何写一个插件</a></li></ul></section></li><li><section class="sidebar-group depth-0"><p class="sidebar-heading open"><span></span> <!----></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/docs/zh-CN/plugins/mouse-wheel.html" class="sidebar-link">mouse-wheel</a></li><li><a href="/docs/zh-CN/plugins/observe-dom.html" class="sidebar-link">observe-dom</a></li><li><a href="/docs/zh-CN/plugins/observe-image.html" class="sidebar-link">observe-image</a></li><li><a href="/docs/zh-CN/plugins/pulldown.html" class="sidebar-link">pulldown</a></li><li><a href="/docs/zh-CN/plugins/pullup.html" class="sidebar-link">pullup</a></li><li><a href="/docs/zh-CN/plugins/scroll-bar.html" class="sidebar-link">scrollbar</a></li><li><a href="/docs/zh-CN/plugins/indicators.html" class="sidebar-link">indicators</a></li><li><a href="/docs/zh-CN/plugins/slide.html" class="sidebar-link">slide</a></li><li><a href="/docs/zh-CN/plugins/wheel.html" aria-current="page" class="active sidebar-link">wheel</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#介绍" class="sidebar-link">介绍</a></li><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#安装" class="sidebar-link">安装</a></li><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#使用" class="sidebar-link">使用</a></li><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#wheel-选项对象" class="sidebar-link">wheel 选项对象</a></li><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#实例方法" class="sidebar-link">实例方法</a></li><li class="sidebar-sub-header"><a href="/docs/zh-CN/plugins/wheel.html#事件" class="sidebar-link">事件</a></li></ul></li><li><a href="/docs/zh-CN/plugins/zoom.html" class="sidebar-link">zoom</a></li><li><a href="/docs/zh-CN/plugins/nested-scroll.html" class="sidebar-link">nested-scroll</a></li><li><a href="/docs/zh-CN/plugins/infinity.html" class="sidebar-link">infinity</a></li><li><a href="/docs/zh-CN/plugins/movable.html" class="sidebar-link">movable</a></li></ul></section></li></ul> </aside> <main class="page"> <div class="theme-default-content content__default"><h1 id="wheel"><a href="#wheel" class="header-anchor">#</a> wheel</h1> <h2 id="介绍"><a href="#介绍" class="header-anchor">#</a> 介绍</h2> <p>wheel 插件,是实现类似 IOS Picker 组件的基石。</p> <h2 id="安装"><a href="#安装" class="header-anchor">#</a> 安装</h2> <div class="language-bash extra-class"><pre class="language-bash"><code><span class="token function">npm</span> <span class="token function">install</span> @better-scroll/wheel <span class="token parameter variable">--save</span>
  50. // or
  51. <span class="token function">yarn</span> <span class="token function">add</span> @better-scroll/wheel
  52. </code></pre></div><h2 id="使用"><a href="#使用" class="header-anchor">#</a> 使用</h2> <p>首先引入 wheel 插件,并通过静态方法 <code>BScroll.use()</code> 注册插件。</p> <div class="language-js extra-class"><pre class="language-js"><code><span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  53. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  54. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  55. </code></pre></div><p>接着在 <code>options</code> 传入正确的配置</p> <div class="language-js extra-class"><pre class="language-js"><code> <span class="token keyword">let</span> bs <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span><span class="token string">'.bs-wrapper'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  56. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span> <span class="token comment">// wheel options 为 true</span>
  57. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  58. </code></pre></div><div class="custom-block tip"><p class="custom-block-title">TIP</p> <p>wheel options 是 true 或者对象,否则插件功能失效,具体请参考<a href="/docs/zh-CN/plugins/wheel.html#wheel-选项对象"> wheel options</a>。</p></div> <div class="custom-block danger"><p class="custom-block-title">危险</p> <p>BetterScroll 结合 wheel 插件只是实现 Picker 效果的 JS 逻辑部分,还有 DOM 模版是需要用户去实现,所幸,对于大多数的 Picker 场景,我们给出了相对应的示例。</p></div> <ul><li><p><strong>基本使用</strong></p> <div class="demo-wrap"><div class="demo-nav"><i class="demo-nav-btn icon-code"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#000"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M10 20l4-16m4 4l4 4-4 4M6 16l-4-4 4-4"></path></svg></i> <div class="v-popover"><div class="trigger" style="display:inline-block;"><i class="demo-nav-btn icon-qrcode"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4v1m6 11h2m-6 0h-2v4m0-11v3m0 0h.01M12 12h4.01M16 20h4M4 12h4m12 0h.01M5 8h2a1 1 0 001-1V5a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1zm12 0h2a1 1 0 001-1V5a1 1 0 00-1-1h-2a1 1 0 00-1 1v2a1 1 0 001 1zM5 20h2a1 1 0 001-1v-2a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1z"></path></svg></i> </div> <div id="popover_0qwjayuumo" aria-hidden="true" tabindex="0" class="tooltip popover vue-popover-theme" style="visibility:hidden;"><div class="wrapper"><div class="tooltip-inner popover-inner" style="position:relative;"><div><div></div></div> <div tabindex="-1" class="resize-observer" data-v-8859cc6c></div></div> <div class="tooltip-arrow popover-arrow"></div></div></div></div> <i class="demo-nav-btn icon-preview"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9.75 17L9 20l-1 1h8l-1-1-.75-3M3 13h18M5 17h14a2 2 0 002-2V5a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"></path></svg></i></div> <div class="demo-code" style="display:;"><div class="demo-code-nav"><button class="demo-code-btn active">Template</button><button class="demo-code-btn">Script</button><button class="demo-code-btn">Style</button></div> <div class="demo-code-content"><div class="demo-code-item" style="display:;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>template</span><span class="token punctuation">&gt;</span></span>
  59. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>container<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  60. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-list<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  61. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-item<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>show<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  62. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>open<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  63. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  64. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  65. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-fade<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  66. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@touchmove.prevent</span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  67. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-move<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  68. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-panel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">&gt;</span></span>
  69. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-choose border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  70. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>cancel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  71. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>confirm<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_confirm<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  72. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>h1</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-title<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>h1</span><span class="token punctuation">&gt;</span></span>
  73. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  74. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-content<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  75. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-top border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  76. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-bottom border-top-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  77. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-wrapper<span class="token punctuation">&quot;</span></span> <span class="token attr-name">ref</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheelWrapper<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  78. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  79. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-scroll<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  80. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span>
  81. <span class="token attr-name">v-for</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>(item, index) in pickerData<span class="token punctuation">&quot;</span></span> <span class="token attr-name">:key</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>index<span class="token punctuation">&quot;</span></span>
  82. <span class="token attr-name">:class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>{'wheel-disabled-item':item.disabled}<span class="token punctuation">&quot;</span></span>
  83. <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-item<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  84. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  85. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  86. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  87. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  88. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-footer<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  89. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  90. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  91. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  92. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  93. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  94. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>template</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>script</span> <span class="token attr-name">type</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>text/ecmascript-6<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token script"><span class="token language-javascript">
  95. <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  96. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  97. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  98. <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
  99. <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
  100. <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
  101. <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
  102. <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
  103. <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
  104. <span class="token keyword">const</span> <span class="token constant">WHEEL_INDEX_CHANGED</span> <span class="token operator">=</span> <span class="token string">'wheelIndexChanged'</span>
  105. <span class="token keyword">const</span> <span class="token constant">DATA</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
  106. <span class="token punctuation">{</span>
  107. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Venomancer'</span><span class="token punctuation">,</span>
  108. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span><span class="token punctuation">,</span>
  109. <span class="token literal-property property">disabled</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
  110. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  111. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Nerubian Weaver'</span><span class="token punctuation">,</span>
  112. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2</span>
  113. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  114. <span class="token punctuation">{</span>
  115. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Spectre'</span><span class="token punctuation">,</span>
  116. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">3</span>
  117. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  118. <span class="token punctuation">{</span>
  119. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Juggernaut'</span><span class="token punctuation">,</span>
  120. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">4</span>
  121. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  122. <span class="token punctuation">{</span>
  123. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Karl'</span><span class="token punctuation">,</span>
  124. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">5</span>
  125. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  126. <span class="token punctuation">{</span>
  127. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Zeus'</span><span class="token punctuation">,</span>
  128. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">6</span>
  129. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  130. <span class="token punctuation">{</span>
  131. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Witch Doctor'</span><span class="token punctuation">,</span>
  132. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">7</span>
  133. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  134. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Lich'</span><span class="token punctuation">,</span>
  135. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">8</span>
  136. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  137. <span class="token punctuation">{</span>
  138. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Oracle'</span><span class="token punctuation">,</span>
  139. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">9</span>
  140. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  141. <span class="token punctuation">{</span>
  142. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Earthshaker'</span><span class="token punctuation">,</span>
  143. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">10</span>
  144. <span class="token punctuation">}</span>
  145. <span class="token punctuation">]</span>
  146. <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
  147. <span class="token literal-property property">name</span><span class="token operator">:</span> <span class="token constant">COMPONENT_NAME</span><span class="token punctuation">,</span>
  148. <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  149. <span class="token keyword">return</span> <span class="token punctuation">{</span>
  150. <span class="token literal-property property">state</span><span class="token operator">:</span> <span class="token constant">STATE_HIDE</span><span class="token punctuation">,</span>
  151. <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token number">2</span><span class="token punctuation">,</span>
  152. <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
  153. <span class="token literal-property property">pickerData</span><span class="token operator">:</span> <span class="token constant">DATA</span>
  154. <span class="token punctuation">}</span>
  155. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  156. <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  157. <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  158. <span class="token comment">/*
  159. * if bs is scrolling, force it stop at the nearest wheel-item
  160. * or you can use 'restorePosition' method as the below
  161. */</span>
  162. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">stop</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  163. <span class="token comment">/*
  164. * if bs is scrolling, restore it to the start position
  165. * it is same with iOS picker and web Select element implementation
  166. * supported at v2.1.0
  167. */</span>
  168. <span class="token comment">// this.wheel.restorePosition()</span>
  169. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  170. <span class="token keyword">const</span> currentSelectedIndex <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndex <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  171. <span class="token keyword">this</span><span class="token punctuation">.</span>selectedText <span class="token operator">=</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span><span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">[</span>currentSelectedIndex<span class="token punctuation">]</span><span class="token punctuation">.</span>text<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">-</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>currentSelectedIndex<span class="token interpolation-punctuation punctuation">}</span></span><span class="token template-punctuation string">`</span></span>
  172. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_SELECT</span><span class="token punctuation">,</span> currentSelectedIndex<span class="token punctuation">)</span>
  173. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  174. <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  175. <span class="token comment">/*
  176. * if bs is scrolling, restore it to the start position
  177. * it is same with iOS picker and web Select element implementation
  178. * supported at v2.1.0
  179. */</span>
  180. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  181. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  182. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CANCEL</span><span class="token punctuation">)</span>
  183. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  184. <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  185. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">===</span> <span class="token constant">STATE_SHOW</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  186. <span class="token keyword">return</span>
  187. <span class="token punctuation">}</span>
  188. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_SHOW</span>
  189. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span><span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  190. <span class="token comment">// waiting for DOM rendered</span>
  191. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$nextTick</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  192. <span class="token keyword">const</span> wrapper <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>$refs<span class="token punctuation">.</span>wheelWrapper<span class="token punctuation">.</span>children<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span>
  193. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">_createWheel</span><span class="token punctuation">(</span>wrapper<span class="token punctuation">)</span>
  194. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  195. <span class="token punctuation">}</span>
  196. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  197. <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  198. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_HIDE</span>
  199. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  200. <span class="token function">_createWheel</span><span class="token punctuation">(</span><span class="token parameter">wheelWrapper</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  201. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span><span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  202. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span>wheelWrapper<span class="token punctuation">,</span> <span class="token punctuation">{</span>
  203. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  204. <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndex<span class="token punctuation">,</span>
  205. <span class="token literal-property property">wheelWrapperClass</span><span class="token operator">:</span> <span class="token string">'wheel-scroll'</span><span class="token punctuation">,</span>
  206. <span class="token literal-property property">wheelItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-item'</span><span class="token punctuation">,</span>
  207. <span class="token literal-property property">wheelDisabledItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
  208. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  209. <span class="token literal-property property">useTransition</span><span class="token operator">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  210. <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
  211. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  212. <span class="token comment">// &lt; v2.1.0</span>
  213. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">on</span><span class="token punctuation">(</span><span class="token string">'scrollEnd'</span><span class="token punctuation">,</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  214. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CHANGE</span><span class="token punctuation">,</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  215. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  216. <span class="token comment">// v2.1.0, only when selectedIndex changed</span>
  217. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">on</span><span class="token punctuation">(</span><span class="token constant">WHEEL_INDEX_CHANGED</span><span class="token punctuation">,</span> <span class="token punctuation">(</span><span class="token parameter">index</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  218. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>index<span class="token punctuation">)</span>
  219. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  220. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
  221. <span class="token keyword">this</span><span class="token punctuation">.</span>wheel<span class="token punctuation">.</span><span class="token function">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  222. <span class="token punctuation">}</span>
  223. <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheel
  224. <span class="token punctuation">}</span>
  225. <span class="token punctuation">}</span>
  226. <span class="token punctuation">}</span>
  227. </span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>script</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-styl extra-class"><pre class="language-styl"><code>&lt;style scoped lang=<span class="token string">&quot;stylus&quot;</span> rel=<span class="token string">&quot;stylesheet/stylus&quot;</span>&gt;
  228. <span class="token selector"><span class="token comment">/* reset */</span>
  229. ul</span>
  230. <span class="token property-declaration"><span class="token property">list-style</span> none</span>
  231. <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
  232. <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
  233. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  234. <span class="token selector">&amp;:before<span class="token punctuation">,</span> &amp;:after</span>
  235. <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">&quot;&quot;</span></span>
  236. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
  237. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  238. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">0</span></span>
  239. <span class="token selector">.border-bottom-1px</span>
  240. <span class="token selector">&amp;:after</span>
  241. <span class="token property-declaration"><span class="token property">border-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  242. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  243. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  244. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  245. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> bottom</span>
  246. <span class="token selector">.border-top-1px</span>
  247. <span class="token selector">&amp;:before</span>
  248. <span class="token property-declaration"><span class="token property">border-top</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  249. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  250. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  251. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  252. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> top</span>
  253. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span></span>
  254. <span class="token selector">.border-top-1px</span>
  255. <span class="token selector">&amp;:before</span>
  256. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  257. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  258. <span class="token selector">.border-bottom-1px</span>
  259. <span class="token selector">&amp;:after</span>
  260. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  261. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  262. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span></span>
  263. <span class="token selector">.border-top-1px</span>
  264. <span class="token selector">&amp;:before</span>
  265. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  266. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  267. <span class="token selector">.border-bottom-1px</span>
  268. <span class="token selector">&amp;:after</span>
  269. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  270. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  271. <span class="token selector">.example-list</span>
  272. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  273. <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
  274. <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
  275. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">2</span><span class="token unit">rem</span></span>
  276. <span class="token selector">.example-item</span>
  277. <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
  278. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0.8</span><span class="token unit">rem</span></span>
  279. <span class="token property-declaration"><span class="token property">border</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">.1</span><span class="token punctuation">)</span></span></span>
  280. <span class="token property-declaration"><span class="token property">box-shadow</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">1</span><span class="token unit">px</span> <span class="token number">2</span><span class="token unit">px</span> <span class="token number">0</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0.1</span><span class="token punctuation">)</span></span></span>
  281. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  282. <span class="token property-declaration"><span class="token property">margin-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">rem</span></span>
  283. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  284. <span class="token selector">&amp;.placeholder</span>
  285. <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
  286. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  287. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  288. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  289. <span class="token selector">.picker</span>
  290. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
  291. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  292. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  293. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
  294. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  295. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  296. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  297. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  298. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  299. <span class="token property-declaration"><span class="token property">background-color</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">37</span><span class="token punctuation">,</span> <span class="token number">38</span><span class="token punctuation">,</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token number">.4</span><span class="token punctuation">)</span></span></span>
  300. <span class="token selector">&amp;.picker-fade-enter<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  301. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  302. <span class="token selector">&amp;.picker-fade-enter-active<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  303. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  304. <span class="token selector">.picker-panel</span>
  305. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  306. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
  307. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  308. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  309. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">273</span><span class="token unit">px</span></span>
  310. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
  311. <span class="token selector">&amp;.picker-move-enter<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  312. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translate3d</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">273</span><span class="token unit">px</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">)</span></span></span>
  313. <span class="token selector">&amp;.picker-move-enter-active<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  314. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  315. <span class="token selector">.picker-choose</span>
  316. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  317. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  318. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
  319. <span class="token selector">.picker-title</span>
  320. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  321. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  322. <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
  323. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  324. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  325. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  326. <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
  327. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  328. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">6</span><span class="token unit">px</span></span>
  329. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">16</span><span class="token unit">px</span></span>
  330. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  331. <span class="token selector">.confirm</span>
  332. <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  333. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
  334. <span class="token selector">&amp;:active</span>
  335. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
  336. <span class="token selector">.cancel</span>
  337. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  338. <span class="token selector">&amp;:active</span>
  339. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
  340. <span class="token selector">.picker-content</span>
  341. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  342. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  343. <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
  344. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
  345. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  346. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  347. <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
  348. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span>
  349. <span class="token selector">.mask-top</span>
  350. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  351. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  352. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to top<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  353. <span class="token selector">.mask-bottom</span>
  354. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  355. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span></span>
  356. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to bottom<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  357. <span class="token selector">.wheel-wrapper</span>
  358. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  359. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">16</span><span class="token unit">px</span></span>
  360. <span class="token selector">.wheel</span>
  361. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  362. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">%</span></span>
  363. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">173</span><span class="token unit">px</span></span>
  364. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  365. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  366. <span class="token selector">.wheel-scroll</span>
  367. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  368. <span class="token property-declaration"><span class="token property">margin-top</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  369. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  370. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  371. <span class="token selector">.wheel-item</span>
  372. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  373. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  374. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  375. <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
  376. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  377. <span class="token selector">&amp;.wheel-disabled-item</span>
  378. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">.2</span><span class="token punctuation">;</span></span>
  379. <span class="token selector">.picker-footer</span>
  380. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  381. &lt;/style&gt;</code></pre></div></div> <i class="demo-code-content-copy"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#ccc"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"></path></svg></i> <!----></div></div> <div class="demo-main"><div class="demo-component-wrap"></div></div></div> <p>单列 Picker 是一个比较常见的效果。你可以通过 <code>selectedIndex</code> 来配置初始化时选中对应索引的 item,<code>wheelDisabledItemClass</code> 配置想要禁用的 item 项来模拟 Web Select 标签 disable 的效果。</p></li> <li><p><strong>多项选择器</strong></p> <div class="demo-wrap"><div class="demo-nav"><i class="demo-nav-btn icon-code"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 20l4-16m4 4l4 4-4 4M6 16l-4-4 4-4"></path></svg></i> <div class="v-popover"><div class="trigger" style="display:inline-block;"><i class="demo-nav-btn icon-qrcode"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4v1m6 11h2m-6 0h-2v4m0-11v3m0 0h.01M12 12h4.01M16 20h4M4 12h4m12 0h.01M5 8h2a1 1 0 001-1V5a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1zm12 0h2a1 1 0 001-1V5a1 1 0 00-1-1h-2a1 1 0 00-1 1v2a1 1 0 001 1zM5 20h2a1 1 0 001-1v-2a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1z"></path></svg></i> </div> <div id="popover_xf462wc4bf" aria-hidden="true" tabindex="0" class="tooltip popover vue-popover-theme" style="visibility:hidden;"><div class="wrapper"><div class="tooltip-inner popover-inner" style="position:relative;"><div><div></div></div> <div tabindex="-1" class="resize-observer" data-v-8859cc6c></div></div> <div class="tooltip-arrow popover-arrow"></div></div></div></div> <i class="demo-nav-btn icon-preview"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9.75 17L9 20l-1 1h8l-1-1-.75-3M3 13h18M5 17h14a2 2 0 002-2V5a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"></path></svg></i></div> <div class="demo-code" style="display:none;"><div class="demo-code-nav"><button class="demo-code-btn active">Template</button><button class="demo-code-btn">Script</button><button class="demo-code-btn">Style</button></div> <div class="demo-code-content"><div class="demo-code-item" style="display:;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>template</span><span class="token punctuation">&gt;</span></span>
  382. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>container<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  383. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-list<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  384. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-item<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>show<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  385. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>open<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  386. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  387. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  388. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-fade<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  389. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@touchmove.prevent</span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  390. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-move<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  391. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-panel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">&gt;</span></span>
  392. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-choose border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  393. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>cancel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  394. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>confirm<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_confirm<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  395. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>h1</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-title<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>h1</span><span class="token punctuation">&gt;</span></span>
  396. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  397. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-content<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  398. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-top border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  399. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-bottom border-top-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  400. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-wrapper<span class="token punctuation">&quot;</span></span> <span class="token attr-name">ref</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheelWrapper<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  401. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-for</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>(data, index) in pickerData<span class="token punctuation">&quot;</span></span> <span class="token attr-name">:key</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>index<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  402. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-scroll<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  403. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span>
  404. <span class="token attr-name">v-for</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>item in data<span class="token punctuation">&quot;</span></span> <span class="token attr-name">:key</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>item.value<span class="token punctuation">&quot;</span></span>
  405. <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-item<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  406. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  407. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  408. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  409. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  410. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-footer<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  411. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  412. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  413. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  414. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  415. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  416. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>template</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>script</span> <span class="token attr-name">type</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>text/ecmascript-6<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token script"><span class="token language-javascript">
  417. <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  418. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  419. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  420. <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
  421. <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
  422. <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
  423. <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
  424. <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
  425. <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
  426. <span class="token keyword">const</span> <span class="token constant">DATA1</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
  427. <span class="token punctuation">{</span>
  428. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Venomancer'</span><span class="token punctuation">,</span>
  429. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span>
  430. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  431. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Nerubian Weaver'</span><span class="token punctuation">,</span>
  432. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2</span>
  433. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  434. <span class="token punctuation">{</span>
  435. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Spectre'</span><span class="token punctuation">,</span>
  436. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">3</span>
  437. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  438. <span class="token punctuation">{</span>
  439. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Juggernaut'</span><span class="token punctuation">,</span>
  440. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">4</span>
  441. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  442. <span class="token punctuation">{</span>
  443. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Karl'</span><span class="token punctuation">,</span>
  444. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">5</span>
  445. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  446. <span class="token punctuation">{</span>
  447. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Zeus'</span><span class="token punctuation">,</span>
  448. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">6</span>
  449. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  450. <span class="token punctuation">{</span>
  451. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Witch Doctor'</span><span class="token punctuation">,</span>
  452. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">7</span>
  453. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  454. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Lich'</span><span class="token punctuation">,</span>
  455. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">8</span>
  456. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  457. <span class="token punctuation">{</span>
  458. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Oracle'</span><span class="token punctuation">,</span>
  459. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">9</span>
  460. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  461. <span class="token punctuation">{</span>
  462. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Earthshaker'</span><span class="token punctuation">,</span>
  463. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">10</span>
  464. <span class="token punctuation">}</span>
  465. <span class="token punctuation">]</span>
  466. <span class="token keyword">const</span> <span class="token constant">DATA2</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
  467. <span class="token punctuation">{</span>
  468. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Durable'</span><span class="token punctuation">,</span>
  469. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'a'</span>
  470. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  471. <span class="token punctuation">{</span>
  472. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Pusher'</span><span class="token punctuation">,</span>
  473. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'b'</span>
  474. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  475. <span class="token punctuation">{</span>
  476. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Carry'</span><span class="token punctuation">,</span>
  477. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'c'</span>
  478. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  479. <span class="token punctuation">{</span>
  480. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Nuker'</span><span class="token punctuation">,</span>
  481. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'d'</span>
  482. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  483. <span class="token punctuation">{</span>
  484. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Support'</span><span class="token punctuation">,</span>
  485. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'e'</span>
  486. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  487. <span class="token punctuation">{</span>
  488. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Jungle'</span><span class="token punctuation">,</span>
  489. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'f'</span>
  490. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  491. <span class="token punctuation">{</span>
  492. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Escape'</span><span class="token punctuation">,</span>
  493. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'g'</span>
  494. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  495. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Initiator'</span><span class="token punctuation">,</span>
  496. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'h'</span>
  497. <span class="token punctuation">}</span>
  498. <span class="token punctuation">]</span>
  499. <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
  500. <span class="token literal-property property">name</span><span class="token operator">:</span> <span class="token constant">COMPONENT_NAME</span><span class="token punctuation">,</span>
  501. <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  502. <span class="token keyword">return</span> <span class="token punctuation">{</span>
  503. <span class="token literal-property property">state</span><span class="token operator">:</span> <span class="token constant">STATE_HIDE</span><span class="token punctuation">,</span>
  504. <span class="token literal-property property">selectedIndexPair</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">,</span>
  505. <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
  506. <span class="token literal-property property">pickerData</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token constant">DATA1</span><span class="token punctuation">,</span> <span class="token constant">DATA2</span><span class="token punctuation">]</span>
  507. <span class="token punctuation">}</span>
  508. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  509. <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  510. <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  511. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  512. <span class="token comment">/*
  513. * if bs is scrolling, force it stop at the nearest wheel-item
  514. * or you can use 'restorePosition' method as the below
  515. */</span>
  516. <span class="token comment">// wheel.stop()</span>
  517. <span class="token comment">/*
  518. * if bs is scrolling, restore it to the start position
  519. * it is same with iOS picker and web Select element implementation
  520. * supported at v2.1.0
  521. */</span>
  522. wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  523. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  524. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  525. <span class="token keyword">const</span> currentSelectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  526. <span class="token keyword">return</span> wheel<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  527. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  528. <span class="token keyword">this</span><span class="token punctuation">.</span>selectedText <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  529. <span class="token keyword">const</span> index <span class="token operator">=</span> currentSelectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
  530. <span class="token keyword">return</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>data<span class="token punctuation">[</span>index<span class="token punctuation">]</span><span class="token punctuation">.</span>text<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">-</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>index<span class="token interpolation-punctuation punctuation">}</span></span><span class="token template-punctuation string">`</span></span>
  531. <span class="token punctuation">}</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span><span class="token string">'__'</span><span class="token punctuation">)</span>
  532. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_SELECT</span><span class="token punctuation">,</span> currentSelectedIndexPair<span class="token punctuation">)</span>
  533. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  534. <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  535. <span class="token comment">/*
  536. * if bs is scrolling, restore it to the start position
  537. * it is same with iOS picker and web Select element implementation
  538. * supported at v2.1.0
  539. */</span>
  540. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  541. wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  542. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  543. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  544. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CANCEL</span><span class="token punctuation">)</span>
  545. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  546. <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  547. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">===</span> <span class="token constant">STATE_SHOW</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  548. <span class="token keyword">return</span>
  549. <span class="token punctuation">}</span>
  550. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_SHOW</span>
  551. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span><span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  552. <span class="token comment">// waiting for DOM rendered</span>
  553. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$nextTick</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  554. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span>
  555. <span class="token keyword">let</span> wheelWrapper <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>$refs<span class="token punctuation">.</span>wheelWrapper
  556. <span class="token keyword">for</span> <span class="token punctuation">(</span><span class="token keyword">let</span> i <span class="token operator">=</span> <span class="token number">0</span><span class="token punctuation">;</span> i <span class="token operator">&lt;</span> <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">.</span>length<span class="token punctuation">;</span> i<span class="token operator">++</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  557. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">_createWheel</span><span class="token punctuation">(</span>wheelWrapper<span class="token punctuation">,</span> i<span class="token punctuation">)</span>
  558. <span class="token punctuation">}</span>
  559. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  560. <span class="token punctuation">}</span>
  561. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  562. <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  563. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_HIDE</span>
  564. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  565. <span class="token function">_createWheel</span><span class="token punctuation">(</span><span class="token parameter">wheelWrapper<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  566. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span><span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  567. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span> <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span>wheelWrapper<span class="token punctuation">.</span>children<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  568. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  569. <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">,</span>
  570. <span class="token literal-property property">wheelWrapperClass</span><span class="token operator">:</span> <span class="token string">'wheel-scroll'</span><span class="token punctuation">,</span>
  571. <span class="token literal-property property">wheelItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-item'</span>
  572. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  573. <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
  574. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  575. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">on</span><span class="token punctuation">(</span><span class="token string">'scrollEnd'</span><span class="token punctuation">,</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  576. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CHANGE</span><span class="token punctuation">,</span> i<span class="token punctuation">,</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  577. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  578. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
  579. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  580. <span class="token punctuation">}</span>
  581. <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
  582. <span class="token punctuation">}</span>
  583. <span class="token punctuation">}</span>
  584. <span class="token punctuation">}</span>
  585. </span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>script</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-styl extra-class"><pre class="language-styl"><code>&lt;style scoped lang=<span class="token string">&quot;stylus&quot;</span> rel=<span class="token string">&quot;stylesheet/stylus&quot;</span>&gt;
  586. <span class="token selector"><span class="token comment">/* reset */</span>
  587. ul</span>
  588. <span class="token property-declaration"><span class="token property">list-style</span> none</span>
  589. <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
  590. <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
  591. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  592. <span class="token selector">&amp;:before<span class="token punctuation">,</span> &amp;:after</span>
  593. <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">&quot;&quot;</span></span>
  594. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
  595. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  596. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">0</span></span>
  597. <span class="token selector">.border-bottom-1px</span>
  598. <span class="token selector">&amp;:after</span>
  599. <span class="token property-declaration"><span class="token property">border-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  600. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  601. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  602. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  603. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> bottom</span>
  604. <span class="token selector">.border-top-1px</span>
  605. <span class="token selector">&amp;:before</span>
  606. <span class="token property-declaration"><span class="token property">border-top</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  607. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  608. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  609. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  610. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> top</span>
  611. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span></span>
  612. <span class="token selector">.border-top-1px</span>
  613. <span class="token selector">&amp;:before</span>
  614. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  615. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  616. <span class="token selector">.border-bottom-1px</span>
  617. <span class="token selector">&amp;:after</span>
  618. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  619. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  620. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span></span>
  621. <span class="token selector">.border-top-1px</span>
  622. <span class="token selector">&amp;:before</span>
  623. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  624. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  625. <span class="token selector">.border-bottom-1px</span>
  626. <span class="token selector">&amp;:after</span>
  627. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  628. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  629. <span class="token selector">.example-list</span>
  630. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  631. <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
  632. <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
  633. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">2</span><span class="token unit">rem</span></span>
  634. <span class="token selector">.example-item</span>
  635. <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
  636. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0.8</span><span class="token unit">rem</span></span>
  637. <span class="token property-declaration"><span class="token property">border</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">.1</span><span class="token punctuation">)</span></span></span>
  638. <span class="token property-declaration"><span class="token property">box-shadow</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">1</span><span class="token unit">px</span> <span class="token number">2</span><span class="token unit">px</span> <span class="token number">0</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0.1</span><span class="token punctuation">)</span></span></span>
  639. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  640. <span class="token property-declaration"><span class="token property">margin-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">rem</span></span>
  641. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  642. <span class="token selector">&amp;.placeholder</span>
  643. <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
  644. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  645. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  646. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  647. <span class="token selector">.picker</span>
  648. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
  649. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  650. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  651. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
  652. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  653. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  654. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  655. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  656. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  657. <span class="token property-declaration"><span class="token property">background-color</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">37</span><span class="token punctuation">,</span> <span class="token number">38</span><span class="token punctuation">,</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token number">.4</span><span class="token punctuation">)</span></span></span>
  658. <span class="token selector">&amp;.picker-fade-enter<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  659. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  660. <span class="token selector">&amp;.picker-fade-enter-active<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  661. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  662. <span class="token selector">.picker-panel</span>
  663. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  664. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
  665. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  666. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  667. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">273</span><span class="token unit">px</span></span>
  668. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
  669. <span class="token selector">&amp;.picker-move-enter<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  670. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translate3d</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">273</span><span class="token unit">px</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">)</span></span></span>
  671. <span class="token selector">&amp;.picker-move-enter-active<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  672. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  673. <span class="token selector">.picker-choose</span>
  674. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  675. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  676. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
  677. <span class="token selector">.picker-title</span>
  678. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  679. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  680. <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
  681. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  682. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  683. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  684. <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
  685. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  686. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">6</span><span class="token unit">px</span></span>
  687. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">16</span><span class="token unit">px</span></span>
  688. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  689. <span class="token selector">.confirm</span>
  690. <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  691. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
  692. <span class="token selector">&amp;:active</span>
  693. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
  694. <span class="token selector">.cancel</span>
  695. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  696. <span class="token selector">&amp;:active</span>
  697. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
  698. <span class="token selector">.picker-content</span>
  699. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  700. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  701. <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
  702. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
  703. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  704. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  705. <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
  706. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span>
  707. <span class="token selector">.mask-top</span>
  708. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  709. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  710. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to top<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  711. <span class="token selector">.mask-bottom</span>
  712. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  713. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span></span>
  714. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to bottom<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  715. <span class="token selector">.wheel-wrapper</span>
  716. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  717. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">16</span><span class="token unit">px</span></span>
  718. <span class="token selector">.wheel</span>
  719. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  720. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">%</span></span>
  721. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">173</span><span class="token unit">px</span></span>
  722. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  723. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  724. <span class="token selector">.wheel-scroll</span>
  725. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  726. <span class="token property-declaration"><span class="token property">margin-top</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  727. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  728. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  729. <span class="token selector">.wheel-item</span>
  730. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  731. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  732. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  733. <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
  734. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  735. <span class="token selector">&amp;.wheel-disabled-item</span>
  736. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">.2</span><span class="token punctuation">;</span></span>
  737. <span class="token selector">.picker-footer</span>
  738. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  739. &lt;/style&gt;</code></pre></div></div> <i class="demo-code-content-copy"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#ccc"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"></path></svg></i> <!----></div></div> <div class="demo-main"><div class="demo-component-wrap"></div></div></div> <p>示例是一个两列的选择器,JS 逻辑部分与单列选择器没有多大的区别,你会发现这个两列选择器之间是没有任何关联,因为它们是两个不同的 BetterScroll 实例。如果你想要实现省市联动的效果,那么得加上一部分代码,让这两个 BetterScroll 实例能够关联起来。请看下一个例子:</p></li> <li><p><strong>城市联动选择器</strong></p> <div class="demo-wrap"><div class="demo-nav"><i class="demo-nav-btn icon-code"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 20l4-16m4 4l4 4-4 4M6 16l-4-4 4-4"></path></svg></i> <div class="v-popover"><div class="trigger" style="display:inline-block;"><i class="demo-nav-btn icon-qrcode"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4v1m6 11h2m-6 0h-2v4m0-11v3m0 0h.01M12 12h4.01M16 20h4M4 12h4m12 0h.01M5 8h2a1 1 0 001-1V5a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1zm12 0h2a1 1 0 001-1V5a1 1 0 00-1-1h-2a1 1 0 00-1 1v2a1 1 0 001 1zM5 20h2a1 1 0 001-1v-2a1 1 0 00-1-1H5a1 1 0 00-1 1v2a1 1 0 001 1z"></path></svg></i> </div> <div id="popover_cmd6tln7tr" aria-hidden="true" tabindex="0" class="tooltip popover vue-popover-theme" style="visibility:hidden;"><div class="wrapper"><div class="tooltip-inner popover-inner" style="position:relative;"><div><div></div></div> <div tabindex="-1" class="resize-observer" data-v-8859cc6c></div></div> <div class="tooltip-arrow popover-arrow"></div></div></div></div> <i class="demo-nav-btn icon-preview"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#666"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9.75 17L9 20l-1 1h8l-1-1-.75-3M3 13h18M5 17h14a2 2 0 002-2V5a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"></path></svg></i></div> <div class="demo-code" style="display:none;"><div class="demo-code-nav"><button class="demo-code-btn active">Template</button><button class="demo-code-btn">Script</button><button class="demo-code-btn">Style</button></div> <div class="demo-code-content"><div class="demo-code-item" style="display:;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>template</span><span class="token punctuation">&gt;</span></span>
  740. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>container<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  741. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-list<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  742. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>example-item<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>show<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  743. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>open<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  744. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  745. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  746. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-fade<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  747. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@touchmove.prevent</span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  748. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>transition</span> <span class="token attr-name">name</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-move<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  749. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-panel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-show</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>state===1<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">&gt;</span></span>
  750. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-choose border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  751. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>cancel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_cancel<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  752. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>span</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>confirm<span class="token punctuation">&quot;</span></span> <span class="token attr-name">@click</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>_confirm<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>span</span><span class="token punctuation">&gt;</span></span>
  753. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>h1</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-title<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>h1</span><span class="token punctuation">&gt;</span></span>
  754. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  755. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-content<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  756. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-top border-bottom-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  757. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>mask-bottom border-top-1px<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  758. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-wrapper<span class="token punctuation">&quot;</span></span> <span class="token attr-name">ref</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheelWrapper<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  759. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel<span class="token punctuation">&quot;</span></span> <span class="token attr-name">v-for</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>(data, index) in pickerData<span class="token punctuation">&quot;</span></span> <span class="token attr-name">:key</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>index<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  760. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>ul</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-scroll<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>
  761. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>li</span>
  762. <span class="token attr-name">v-for</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>item in data<span class="token punctuation">&quot;</span></span> <span class="token attr-name">:key</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>item.value<span class="token punctuation">&quot;</span></span>
  763. <span class="token attr-name">:class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>{'wheel-disabled-item':item.disabled}<span class="token punctuation">&quot;</span></span>
  764. <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>wheel-item<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>li</span><span class="token punctuation">&gt;</span></span>
  765. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>ul</span><span class="token punctuation">&gt;</span></span>
  766. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  767. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  768. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  769. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>picker-footer<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  770. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  771. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  772. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  773. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>transition</span><span class="token punctuation">&gt;</span></span>
  774. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">&gt;</span></span>
  775. <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>template</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-vue extra-class"><pre class="language-vue"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>script</span> <span class="token attr-name">type</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">&quot;</span>text/ecmascript-6<span class="token punctuation">&quot;</span></span><span class="token punctuation">&gt;</span></span><span class="token script"><span class="token language-javascript">
  776. <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  777. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  778. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  779. <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
  780. <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
  781. <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
  782. <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
  783. <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
  784. <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
  785. <span class="token keyword">const</span> <span class="token constant">DATA</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
  786. <span class="token punctuation">{</span>
  787. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'北京市'</span><span class="token punctuation">,</span>
  788. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'110000'</span><span class="token punctuation">,</span>
  789. <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
  790. <span class="token punctuation">{</span>
  791. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">&quot;北京市&quot;</span><span class="token punctuation">,</span>
  792. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'110100'</span>
  793. <span class="token punctuation">}</span>
  794. <span class="token punctuation">]</span>
  795. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  796. <span class="token punctuation">{</span>
  797. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'天津市'</span><span class="token punctuation">,</span>
  798. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'120000'</span><span class="token punctuation">,</span>
  799. <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
  800. <span class="token punctuation">{</span>
  801. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">&quot;天津市&quot;</span><span class="token punctuation">,</span>
  802. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'120000'</span>
  803. <span class="token punctuation">}</span>
  804. <span class="token punctuation">]</span>
  805. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  806. <span class="token punctuation">{</span>
  807. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'河北省'</span><span class="token punctuation">,</span>
  808. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130000'</span><span class="token punctuation">,</span>
  809. <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
  810. <span class="token punctuation">{</span>
  811. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'石家庄市'</span><span class="token punctuation">,</span>
  812. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130100'</span>
  813. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  814. <span class="token punctuation">{</span>
  815. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'唐山市'</span><span class="token punctuation">,</span>
  816. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130200'</span>
  817. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  818. <span class="token punctuation">{</span>
  819. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'秦皇岛市'</span><span class="token punctuation">,</span>
  820. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130300'</span>
  821. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  822. <span class="token punctuation">{</span>
  823. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'邯郸市'</span><span class="token punctuation">,</span>
  824. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130400'</span>
  825. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  826. <span class="token punctuation">{</span>
  827. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'邢台市'</span><span class="token punctuation">,</span>
  828. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130500'</span>
  829. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  830. <span class="token punctuation">{</span>
  831. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'保定市'</span><span class="token punctuation">,</span>
  832. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130600'</span>
  833. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  834. <span class="token punctuation">{</span>
  835. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'张家口市'</span><span class="token punctuation">,</span>
  836. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130700'</span>
  837. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  838. <span class="token punctuation">{</span>
  839. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'承德市'</span><span class="token punctuation">,</span>
  840. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130800'</span>
  841. <span class="token punctuation">}</span>
  842. <span class="token punctuation">]</span>
  843. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  844. <span class="token punctuation">{</span>
  845. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'山西省'</span><span class="token punctuation">,</span>
  846. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140000'</span><span class="token punctuation">,</span>
  847. <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
  848. <span class="token punctuation">{</span>
  849. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'太原市'</span><span class="token punctuation">,</span>
  850. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140100'</span>
  851. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  852. <span class="token punctuation">{</span>
  853. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'大同市'</span><span class="token punctuation">,</span>
  854. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140200'</span>
  855. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  856. <span class="token punctuation">{</span>
  857. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'阳泉市'</span><span class="token punctuation">,</span>
  858. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140300'</span>
  859. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  860. <span class="token punctuation">{</span>
  861. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'长治市'</span><span class="token punctuation">,</span>
  862. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140400'</span>
  863. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  864. <span class="token punctuation">{</span>
  865. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'晋城市'</span><span class="token punctuation">,</span>
  866. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140500'</span>
  867. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  868. <span class="token punctuation">{</span>
  869. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'朔州市'</span><span class="token punctuation">,</span>
  870. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140600'</span>
  871. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  872. <span class="token punctuation">{</span>
  873. <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'晋中市'</span><span class="token punctuation">,</span>
  874. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140700'</span>
  875. <span class="token punctuation">}</span>
  876. <span class="token punctuation">]</span>
  877. <span class="token punctuation">}</span>
  878. <span class="token punctuation">]</span>
  879. <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
  880. <span class="token literal-property property">name</span><span class="token operator">:</span> <span class="token constant">COMPONENT_NAME</span><span class="token punctuation">,</span>
  881. <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  882. <span class="token keyword">return</span> <span class="token punctuation">{</span>
  883. <span class="token literal-property property">state</span><span class="token operator">:</span> <span class="token constant">STATE_HIDE</span><span class="token punctuation">,</span>
  884. <span class="token literal-property property">selectedIndexPair</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">,</span>
  885. <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
  886. <span class="token literal-property property">pickerData</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token punctuation">]</span>
  887. <span class="token punctuation">}</span>
  888. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  889. <span class="token function">created</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  890. <span class="token comment">// generate data</span>
  891. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">_loadPickerData</span><span class="token punctuation">(</span><span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair<span class="token punctuation">,</span> <span class="token keyword">undefined</span> <span class="token comment">/* no prevSelectedIndex due to instantiating */</span><span class="token punctuation">)</span>
  892. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  893. <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  894. <span class="token function">_loadPickerData</span> <span class="token punctuation">(</span><span class="token parameter">newIndexPair<span class="token punctuation">,</span> oldIndexPair</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  895. <span class="token keyword">let</span> provinces
  896. <span class="token keyword">let</span> cities
  897. <span class="token comment">// first instantiated</span>
  898. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span>oldIndexPair<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  899. provinces <span class="token operator">=</span> <span class="token constant">DATA</span><span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter"><span class="token punctuation">{</span> value<span class="token punctuation">,</span> text <span class="token punctuation">}</span></span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">(</span><span class="token punctuation">{</span> value<span class="token punctuation">,</span> text <span class="token punctuation">}</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  900. cities <span class="token operator">=</span> <span class="token constant">DATA</span><span class="token punctuation">[</span>newIndexPair<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">]</span><span class="token punctuation">.</span>children
  901. <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData <span class="token operator">=</span> <span class="token punctuation">[</span>provinces<span class="token punctuation">,</span> cities<span class="token punctuation">]</span>
  902. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
  903. <span class="token comment">// provinces'index changed, refresh cities data</span>
  904. <span class="token keyword">if</span> <span class="token punctuation">(</span>newIndexPair<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span> <span class="token operator">!==</span> oldIndexPair<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  905. cities <span class="token operator">=</span> <span class="token constant">DATA</span><span class="token punctuation">[</span>newIndexPair<span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">]</span><span class="token punctuation">.</span>children
  906. <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">.</span><span class="token function">splice</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token punctuation">,</span> <span class="token number">1</span><span class="token punctuation">,</span> cities<span class="token punctuation">)</span>
  907. <span class="token comment">// Since cities data changed</span>
  908. <span class="token comment">// refresh better-scroll to recaculate scrollHeight</span>
  909. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$nextTick</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  910. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  911. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  912. <span class="token punctuation">}</span>
  913. <span class="token punctuation">}</span>
  914. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  915. <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  916. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  917. <span class="token comment">/*
  918. * if bs is scrolling, force it stop at the nearest wheel-item
  919. * or you can use 'restorePosition' method as the below
  920. */</span>
  921. <span class="token comment">// wheel.stop()</span>
  922. <span class="token comment">/*
  923. * if bs is scrolling, restore it to the start position
  924. * it is same with iOS picker and web Select element implementation
  925. * supported at v2.1.0
  926. */</span>
  927. wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  928. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  929. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  930. <span class="token keyword">const</span> currentSelectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  931. <span class="token keyword">return</span> wheel<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  932. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  933. <span class="token keyword">this</span><span class="token punctuation">.</span>selectedText <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">data<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  934. <span class="token keyword">const</span> index <span class="token operator">=</span> currentSelectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
  935. <span class="token keyword">return</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>data<span class="token punctuation">[</span>index<span class="token punctuation">]</span><span class="token punctuation">.</span>text<span class="token interpolation-punctuation punctuation">}</span></span><span class="token string">-</span><span class="token interpolation"><span class="token interpolation-punctuation punctuation">${</span>index<span class="token interpolation-punctuation punctuation">}</span></span><span class="token template-punctuation string">`</span></span>
  936. <span class="token punctuation">}</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span><span class="token string">'__'</span><span class="token punctuation">)</span>
  937. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_SELECT</span><span class="token punctuation">,</span> currentSelectedIndexPair<span class="token punctuation">)</span>
  938. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  939. <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  940. <span class="token comment">/*
  941. * if bs is scrolling, restore it to the start position
  942. * it is same with iOS picker and web Select element implementation
  943. * supported at v2.1.0
  944. */</span>
  945. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  946. wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  947. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  948. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  949. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CANCEL</span><span class="token punctuation">)</span>
  950. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  951. <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  952. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">===</span> <span class="token constant">STATE_SHOW</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  953. <span class="token keyword">return</span>
  954. <span class="token punctuation">}</span>
  955. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_SHOW</span>
  956. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span><span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  957. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$nextTick</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  958. <span class="token keyword">this</span><span class="token punctuation">.</span>wheels <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token punctuation">]</span>
  959. <span class="token keyword">let</span> wheelWrapper <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>$refs<span class="token punctuation">.</span>wheelWrapper
  960. <span class="token keyword">for</span> <span class="token punctuation">(</span><span class="token keyword">let</span> i <span class="token operator">=</span> <span class="token number">0</span><span class="token punctuation">;</span> i <span class="token operator">&lt;</span> <span class="token keyword">this</span><span class="token punctuation">.</span>pickerData<span class="token punctuation">.</span>length<span class="token punctuation">;</span> i<span class="token operator">++</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  961. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">_createWheel</span><span class="token punctuation">(</span>wheelWrapper<span class="token punctuation">,</span> i<span class="token punctuation">)</span>
  962. <span class="token punctuation">}</span>
  963. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  964. <span class="token punctuation">}</span>
  965. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  966. <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  967. <span class="token keyword">this</span><span class="token punctuation">.</span>state <span class="token operator">=</span> <span class="token constant">STATE_HIDE</span>
  968. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  969. <span class="token function">_createWheel</span><span class="token punctuation">(</span><span class="token parameter">wheelWrapper<span class="token punctuation">,</span> i</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  970. <span class="token keyword">const</span> wheels <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels
  971. <span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  972. wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span> <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span>wheelWrapper<span class="token punctuation">.</span>children<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  973. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  974. <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">,</span>
  975. <span class="token literal-property property">wheelWrapperClass</span><span class="token operator">:</span> <span class="token string">'wheel-scroll'</span><span class="token punctuation">,</span>
  976. <span class="token literal-property property">wheelItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-item'</span>
  977. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  978. <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
  979. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  980. <span class="token comment">// when any of wheels'scrolling ended , refresh data</span>
  981. <span class="token keyword">let</span> prevSelectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair
  982. wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">on</span><span class="token punctuation">(</span><span class="token string">'scrollEnd'</span><span class="token punctuation">,</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  983. <span class="token keyword">const</span> currentSelectedIndexPair <span class="token operator">=</span> wheels<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token parameter">wheel</span> <span class="token operator">=&gt;</span> wheel<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  984. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">_loadPickerData</span><span class="token punctuation">(</span>currentSelectedIndexPair<span class="token punctuation">,</span> prevSelectedIndexPair<span class="token punctuation">)</span>
  985. prevSelectedIndexPair <span class="token operator">=</span> currentSelectedIndexPair
  986. <span class="token keyword">this</span><span class="token punctuation">.</span><span class="token function">$emit</span><span class="token punctuation">(</span><span class="token constant">EVENT_CHANGE</span><span class="token punctuation">,</span> i<span class="token punctuation">,</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span>
  987. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  988. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
  989. wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  990. <span class="token punctuation">}</span>
  991. <span class="token keyword">return</span> wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
  992. <span class="token punctuation">}</span>
  993. <span class="token punctuation">}</span>
  994. <span class="token punctuation">}</span>
  995. </span></span><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>script</span><span class="token punctuation">&gt;</span></span></code></pre></div></div><div class="demo-code-item" style="display:none;"><div class="language-styl extra-class"><pre class="language-styl"><code>&lt;style scoped lang=<span class="token string">&quot;stylus&quot;</span> rel=<span class="token string">&quot;stylesheet/stylus&quot;</span>&gt;
  996. <span class="token selector"><span class="token comment">/* reset */</span>
  997. ul</span>
  998. <span class="token property-declaration"><span class="token property">list-style</span> none</span>
  999. <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
  1000. <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
  1001. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  1002. <span class="token selector">&amp;:before<span class="token punctuation">,</span> &amp;:after</span>
  1003. <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">&quot;&quot;</span></span>
  1004. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
  1005. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  1006. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">0</span></span>
  1007. <span class="token selector">.border-bottom-1px</span>
  1008. <span class="token selector">&amp;:after</span>
  1009. <span class="token property-declaration"><span class="token property">border-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  1010. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1011. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1012. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1013. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> bottom</span>
  1014. <span class="token selector">.border-top-1px</span>
  1015. <span class="token selector">&amp;:before</span>
  1016. <span class="token property-declaration"><span class="token property">border-top</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token hexcode">#ebebeb</span></span>
  1017. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1018. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1019. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1020. <span class="token property-declaration"><span class="token property">transform-origin</span><span class="token punctuation">:</span> <span class="token number">0</span> top</span>
  1021. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">2</span><span class="token punctuation">)</span></span>
  1022. <span class="token selector">.border-top-1px</span>
  1023. <span class="token selector">&amp;:before</span>
  1024. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  1025. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  1026. <span class="token selector">.border-bottom-1px</span>
  1027. <span class="token selector">&amp;:after</span>
  1028. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">200</span><span class="token unit">%</span></span>
  1029. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.5</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  1030. <span class="token atrule-declaration"><span class="token atrule">@media</span> <span class="token punctuation">(</span>-webkit-min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token punctuation">(</span>min-device-pixel-ratio<span class="token punctuation">:</span> <span class="token number">3</span><span class="token punctuation">)</span></span>
  1031. <span class="token selector">.border-top-1px</span>
  1032. <span class="token selector">&amp;:before</span>
  1033. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  1034. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  1035. <span class="token selector">.border-bottom-1px</span>
  1036. <span class="token selector">&amp;:after</span>
  1037. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">300</span><span class="token unit">%</span></span>
  1038. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">scale</span><span class="token punctuation">(</span><span class="token number">.333</span><span class="token punctuation">)</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span></span>
  1039. <span class="token selector">.example-list</span>
  1040. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  1041. <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
  1042. <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
  1043. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">2</span><span class="token unit">rem</span></span>
  1044. <span class="token selector">.example-item</span>
  1045. <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
  1046. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0.8</span><span class="token unit">rem</span></span>
  1047. <span class="token property-declaration"><span class="token property">border</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span> solid <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">.1</span><span class="token punctuation">)</span></span></span>
  1048. <span class="token property-declaration"><span class="token property">box-shadow</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">1</span><span class="token unit">px</span> <span class="token number">2</span><span class="token unit">px</span> <span class="token number">0</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token number">0.1</span><span class="token punctuation">)</span></span></span>
  1049. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  1050. <span class="token property-declaration"><span class="token property">margin-bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">rem</span></span>
  1051. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  1052. <span class="token selector">&amp;.placeholder</span>
  1053. <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
  1054. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1055. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1056. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1057. <span class="token selector">.picker</span>
  1058. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
  1059. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1060. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1061. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
  1062. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1063. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1064. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  1065. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  1066. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  1067. <span class="token property-declaration"><span class="token property">background-color</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">37</span><span class="token punctuation">,</span> <span class="token number">38</span><span class="token punctuation">,</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token number">.4</span><span class="token punctuation">)</span></span></span>
  1068. <span class="token selector">&amp;.picker-fade-enter<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  1069. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1070. <span class="token selector">&amp;.picker-fade-enter-active<span class="token punctuation">,</span> &amp;.picker-fade-leave-active</span>
  1071. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  1072. <span class="token selector">.picker-panel</span>
  1073. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  1074. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
  1075. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1076. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1077. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">273</span><span class="token unit">px</span></span>
  1078. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
  1079. <span class="token selector">&amp;.picker-move-enter<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  1080. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translate3d</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">,</span> <span class="token number">273</span><span class="token unit">px</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">)</span></span></span>
  1081. <span class="token selector">&amp;.picker-move-enter-active<span class="token punctuation">,</span> &amp;.picker-move-leave-active</span>
  1082. <span class="token property-declaration"><span class="token property">transition</span><span class="token punctuation">:</span> all <span class="token number">.3</span><span class="token unit">s</span> ease-<span class="token operator">in</span>-out</span>
  1083. <span class="token selector">.picker-choose</span>
  1084. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  1085. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  1086. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
  1087. <span class="token selector">.picker-title</span>
  1088. <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1089. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">60</span><span class="token unit">px</span></span>
  1090. <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
  1091. <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
  1092. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  1093. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  1094. <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
  1095. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  1096. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">6</span><span class="token unit">px</span></span>
  1097. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">16</span><span class="token unit">px</span></span>
  1098. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">14</span><span class="token unit">px</span></span>
  1099. <span class="token selector">.confirm</span>
  1100. <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1101. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
  1102. <span class="token selector">&amp;:active</span>
  1103. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
  1104. <span class="token selector">.cancel</span>
  1105. <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1106. <span class="token selector">&amp;:active</span>
  1107. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
  1108. <span class="token selector">.picker-content</span>
  1109. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
  1110. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  1111. <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
  1112. <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
  1113. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">100</span><span class="token unit">%</span></span>
  1114. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  1115. <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
  1116. <span class="token property-declaration"><span class="token property">transform</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">translateZ</span><span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span></span></span>
  1117. <span class="token selector">.mask-top</span>
  1118. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  1119. <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1120. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to top<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  1121. <span class="token selector">.mask-bottom</span>
  1122. <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
  1123. <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">px</span></span>
  1124. <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token func"><span class="token function">linear-gradient</span><span class="token punctuation">(</span>to bottom<span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.4</span><span class="token punctuation">)</span><span class="token punctuation">,</span> <span class="token func"><span class="token function">rgba</span><span class="token punctuation">(</span><span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">255</span><span class="token punctuation">,</span> <span class="token number">0.8</span><span class="token punctuation">)</span><span class="token punctuation">)</span></span></span></span></span>
  1125. <span class="token selector">.wheel-wrapper</span>
  1126. <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
  1127. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span> <span class="token number">16</span><span class="token unit">px</span></span>
  1128. <span class="token selector">.wheel</span>
  1129. <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
  1130. <span class="token property-declaration"><span class="token property">width</span><span class="token punctuation">:</span> <span class="token number">1</span><span class="token unit">%</span></span>
  1131. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">173</span><span class="token unit">px</span></span>
  1132. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  1133. <span class="token property-declaration"><span class="token property">font-size</span><span class="token punctuation">:</span> <span class="token number">18</span><span class="token unit">px</span></span>
  1134. <span class="token selector">.wheel-scroll</span>
  1135. <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
  1136. <span class="token property-declaration"><span class="token property">margin-top</span><span class="token punctuation">:</span> <span class="token number">68</span><span class="token unit">px</span></span>
  1137. <span class="token property-declaration"><span class="token property">line-height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  1138. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  1139. <span class="token selector">.wheel-item</span>
  1140. <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
  1141. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">36</span><span class="token unit">px</span></span>
  1142. <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
  1143. <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
  1144. <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
  1145. <span class="token selector">&amp;.wheel-disabled-item</span>
  1146. <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">.2</span><span class="token punctuation">;</span></span>
  1147. <span class="token selector">.picker-footer</span>
  1148. <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">20</span><span class="token unit">px</span></span>
  1149. &lt;/style&gt;</code></pre></div></div> <i class="demo-code-content-copy"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="#ccc"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"></path></svg></i> <!----></div></div> <div class="demo-main"><div class="demo-component-wrap"></div></div></div> <p>城市联动 Picker 的效果,必须通过 JS 部分逻辑将不同 BetterScroll 的实例联系起来,不管是省市,还是省市区的联动,亦是如此。</p></li></ul> <h2 id="wheel-选项对象"><a href="#wheel-选项对象" class="header-anchor">#</a> wheel 选项对象</h2> <div class="custom-block tip"><p class="custom-block-title">提示</p> <p>当 wheel 配置为 true 的时候,插件内部使用的是默认的插件选项对象。</p> <div class="language-js extra-class"><pre class="language-js"><code><span class="token keyword">const</span> bs <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span><span class="token string">'.wrapper'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  1150. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
  1151. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  1152. <span class="token comment">// 相当于</span>
  1153. <span class="token keyword">const</span> bs <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span><span class="token string">'.wrapper'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  1154. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
  1155. <span class="token literal-property property">wheelWrapperClass</span><span class="token operator">:</span> <span class="token string">'wheel-scroll'</span><span class="token punctuation">,</span>
  1156. <span class="token literal-property property">wheelItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-item'</span><span class="token punctuation">,</span>
  1157. <span class="token literal-property property">rotate</span><span class="token operator">:</span> <span class="token number">25</span><span class="token punctuation">,</span>
  1158. <span class="token literal-property property">adjustTime</span><span class="token operator">:</span> <span class="token number">400</span><span class="token punctuation">,</span>
  1159. <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">,</span>
  1160. <span class="token literal-property property">wheelDisabledItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
  1161. <span class="token punctuation">}</span>
  1162. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  1163. </code></pre></div></div> <h3 id="selectedindex"><a href="#selectedindex" class="header-anchor">#</a> selectedIndex</h3> <ul><li><strong>类型</strong>:<code>number</code></li> <li><strong>默认值</strong>:<code>0</code></li></ul> <p>实例化 Wheel,默认选中第 selectedIndex 项,索引从 0 开始。</p> <h3 id="rotate"><a href="#rotate" class="header-anchor">#</a> rotate</h3> <ul><li><strong>类型</strong>:<code>number</code></li> <li><strong>默认值</strong>:<code>25</code></li></ul> <p>当滚动 wheel 时,wheel item 的弯曲程度。</p> <h3 id="adjusttime"><a href="#adjusttime" class="header-anchor">#</a> adjustTime</h3> <ul><li><strong>类型</strong>:<code>number</code></li> <li><strong>默认值</strong>:<code>400</code>(ms)</li></ul> <p>当点击某一项的时候,滚动过去的动画时长。</p> <h3 id="wheelwrapperclass"><a href="#wheelwrapperclass" class="header-anchor">#</a> wheelWrapperClass</h3> <ul><li><strong>类型</strong>:<code>string</code></li> <li><strong>默认值</strong>:<code>wheel-scroll</code></li></ul> <p>滚动元素的 className,这里的「滚动元素」 指的就是 BetterScroll 的 content 元素。</p> <h3 id="wheelitemclass"><a href="#wheelitemclass" class="header-anchor">#</a> wheelItemClass</h3> <ul><li><strong>类型</strong>:<code>string</code></li> <li><strong>默认值</strong>:<code>wheel-item</code></li></ul> <p>滚动元素的子元素的样式。</p> <h3 id="wheeldisableditemclass"><a href="#wheeldisableditemclass" class="header-anchor">#</a> wheelDisabledItemClass</h3> <ul><li><strong>类型</strong>:<code>string</code></li> <li><strong>默认值</strong>:<code>wheel-disabled-item</code></li></ul> <p>滚动元素中想要禁用的子元素,类似于 <code>select</code> 元素中禁用的 <code>option</code> 效果。wheel 插件的内部根据 <code>wheelDisabledItemClass</code> 配置来判断是否将该项指定为 disabled 状态。</p> <h2 id="实例方法"><a href="#实例方法" class="header-anchor">#</a> 实例方法</h2> <div class="custom-block tip"><p class="custom-block-title">提示</p> <p>以下方法皆已代理至 BetterScroll 实例,例如:</p> <div class="language-js extra-class"><pre class="language-js"><code><span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  1164. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  1165. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  1166. <span class="token keyword">const</span> bs <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span><span class="token string">'.bs-wrapper'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  1167. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
  1168. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  1169. bs<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  1170. bs<span class="token punctuation">.</span><span class="token function">wheelTo</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token punctuation">,</span> <span class="token number">300</span><span class="token punctuation">)</span>
  1171. </code></pre></div></div> <h3 id="getselectedindex"><a href="#getselectedindex" class="header-anchor">#</a> getSelectedIndex()</h3> <ul><li><strong>返回值</strong>:当前选中项的 index,下标从 0 开始</li></ul> <p>获取当前选中项的索引。</p> <h3 id="wheelto-index-0-time-0-ease"><a href="#wheelto-index-0-time-0-ease" class="header-anchor">#</a> wheelTo(index = 0, time = 0, [ease])</h3> <ul><li><strong>参数</strong>:
  1172. <ul><li><code>{ number } index</code>:选项索引</li> <li><code>{ number } time</code>:动画时长</li> <li><code>{ number } ease&lt;可选&gt;</code>:动画时长。缓动效果配置,参考 <a href="https://github.com/ustbhuangyi/better-scroll/blob/dev/packages/shared-utils/src/ease.ts" target="_blank" rel="noopener noreferrer">ease.ts<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a>,默认是 <code>bounce</code> 效果</li></ul></li></ul> <p>滚动至对应索引的列表项。</p> <h3 id="stop"><a href="#stop" class="header-anchor">#</a> stop() <span class="badge tip" style="vertical-align:top;" data-v-15b7b770>2.1.0</span></h3> <p>强制让滚动的 BetterScroll 停止下来,并且吸附至当前距离最近的 wheel-item 的位置。</p> <h3 id="restoreposition"><a href="#restoreposition" class="header-anchor">#</a> restorePosition() <span class="badge tip" style="vertical-align:top;" data-v-15b7b770>2.1.0</span></h3> <p>强制让滚动的 BetterScroll 停止下来,并且恢复至滚动开始前的位置。</p> <div class="custom-block tip"><p class="custom-block-title">提示</p> <p>以上两个方法只对处于<strong>滚动中的 BetterScroll</strong> 有效,并且 <code>restorePosition</code> 是与原生的 iOS picker 组件的效果一模一样,用户可以根据自己的需求选择对应的方法。</p></div> <h2 id="事件"><a href="#事件" class="header-anchor">#</a> 事件</h2> <h3 id="wheelindexchanged"><a href="#wheelindexchanged" class="header-anchor">#</a> wheelIndexChanged <span class="badge tip" style="vertical-align:top;" data-v-15b7b770>2.1.0</span></h3> <ul><li><strong>参数</strong>:当前选中的 wheel-item 的索引。</li> <li><strong>触发时机</strong>:当列表项发生改变的时候。</li></ul> <div class="language-js extra-class"><pre class="language-js"><code><span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
  1173. <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
  1174. BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
  1175. <span class="token keyword">const</span> bs <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">BScroll</span><span class="token punctuation">(</span><span class="token string">'.bs-wrapper'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  1176. <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
  1177. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  1178. bs<span class="token punctuation">.</span><span class="token function">on</span><span class="token punctuation">(</span><span class="token string">'wheelIndexChanged'</span><span class="token punctuation">,</span> <span class="token punctuation">(</span><span class="token parameter">index</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  1179. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>index<span class="token punctuation">)</span>
  1180. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  1181. </code></pre></div></div> <footer class="page-edit"><div class="edit-link"><a href="https://github.com/ustbhuangyi/better-scroll/edit/dev/packages/vuepress-docs/docs/zh-CN/plugins/wheel.md" target="_blank" rel="noopener noreferrer">在 GitHub 上编辑此页</a> <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></div> <div class="last-updated"><span class="prefix">上次更新:</span> <span class="time">2021/2/1 23:07:17</span></div></footer> <div class="page-nav"><p class="inner"><span class="prev">
  1182. <a href="/docs/zh-CN/plugins/slide.html" class="prev">
  1183. slide
  1184. </a></span> <span class="next"><a href="/docs/zh-CN/plugins/zoom.html">
  1185. zoom
  1186. </a>
  1187. </span></p></div> </main></div><div class="global-ui"><!----></div></div>
  1188. <script src="/docs/assets/js/app.c71b64d3.js" defer></script><script src="/docs/assets/js/5.d6412664.js" defer></script><script src="/docs/assets/js/4.4855b9ef.js" defer></script><script src="/docs/assets/js/3.481632b4.js" defer></script><script src="/docs/assets/js/121.e41f8100.js" defer></script><script src="/docs/assets/js/56.cd04bae9.js" defer></script><script src="/docs/assets/js/7.518ccda7.js" defer></script>
  1189. </body>
  1190. </html>