1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243 |
- <!DOCTYPE html>
- <html lang="zh-CN">
- <head>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width,initial-scale=1">
- <title>wheel | BetterScroll 2.0</title>
- <meta name="generator" content="VuePress 1.9.10">
- <link rel="shortcut icon" href="/docs/assets/bs.ico" type="images/x-icon">
- <script src="https://www.googletagmanager.com/gtag/js?id=G-7E85TW7P27"></script>
- <script type="text/javascript">
- window.dataLayer = window.dataLayer || [];
- function gtag(){dataLayer.push(arguments);}
- gtag('js', new Date());
- gtag('config', 'G-7E85TW7P27');
- </script>
- <meta name="description" content="Make Scroll Perfect">
-
- <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">
- <link rel="stylesheet" href="/docs/assets/css/0.styles.0cd93813.css">
- </head>
- <body>
- <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">
- 指南
- </a></div><div class="nav-item"><a href="/docs/zh-CN/plugins/" class="nav-link router-link-active">
- 插件
- </a></div><div class="nav-item"><a href="/docs/zh-CN/FAQ/" class="nav-link">
- 常见问题
- </a></div><div class="nav-item"><a href="https://github.com/ustbhuangyi/better-scroll/issues" target="_blank" rel="noopener noreferrer" class="nav-link external">
- 讨论
- <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">
- English
- </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">
- 简体中文
- </a></li></ul></div></div> <a href="https://github.com/ustbhuangyi/better-scroll" target="_blank" rel="noopener noreferrer" class="repo-link">
- GitHub
- <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">
- 指南
- </a></div><div class="nav-item"><a href="/docs/zh-CN/plugins/" class="nav-link router-link-active">
- 插件
- </a></div><div class="nav-item"><a href="/docs/zh-CN/FAQ/" class="nav-link">
- 常见问题
- </a></div><div class="nav-item"><a href="https://github.com/ustbhuangyi/better-scroll/issues" target="_blank" rel="noopener noreferrer" class="nav-link external">
- 讨论
- <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">
- English
- </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">
- 简体中文
- </a></li></ul></div></div> <a href="https://github.com/ustbhuangyi/better-scroll" target="_blank" rel="noopener noreferrer" class="repo-link">
- GitHub
- <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>
- // or
- <span class="token function">yarn</span> <span class="token function">add</span> @better-scroll/wheel
- </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>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- </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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- </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"><</span>template</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>container<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-list<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-item<span class="token punctuation">"</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">"</span>show<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>open<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-fade<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-move<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-panel<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-choose border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>cancel<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>confirm<span class="token punctuation">"</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">"</span>_confirm<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-title<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>h1</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-content<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-top border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-bottom border-top-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-wrapper<span class="token punctuation">"</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">"</span>wheelWrapper<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-scroll<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</span>li</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">"</span>(item, index) in pickerData<span class="token punctuation">"</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">"</span>index<span class="token punctuation">"</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">"</span>{'wheel-disabled-item':item.disabled}<span class="token punctuation">"</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">"</span>wheel-item<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-footer<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>template</span><span class="token punctuation">></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"><</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">"</span>text/ecmascript-6<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token script"><span class="token language-javascript">
- <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
- <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
- <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>
- <span class="token keyword">const</span> <span class="token constant">DATA</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Venomancer'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span><span class="token punctuation">,</span>
- <span class="token literal-property property">disabled</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
- <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>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Spectre'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">3</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Juggernaut'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">4</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Karl'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">5</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Zeus'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">6</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <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>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">7</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Lich'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">8</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Oracle'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">9</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Earthshaker'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">10</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
- <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>
- <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token keyword">return</span> <span class="token punctuation">{</span>
- <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>
- <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token number">2</span><span class="token punctuation">,</span>
- <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">pickerData</span><span class="token operator">:</span> <span class="token constant">DATA</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, force it stop at the nearest wheel-item
- * or you can use 'restorePosition' method as the below
- */</span>
- <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>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- <span class="token comment">// this.wheel.restorePosition()</span>
- <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>
- <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>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- <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>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <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>
- <span class="token keyword">return</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 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>
- <span class="token comment">// waiting for DOM rendered</span>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</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_HIDE</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <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>
- <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>
- <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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <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>
- <span class="token literal-property property">wheelDisabledItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token literal-property property">useTransition</span><span class="token operator">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
- <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token comment">// < v2.1.0</span>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token comment">// v2.1.0, only when selectedIndex changed</span>
- <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">=></span> <span class="token punctuation">{</span>
- console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>index<span class="token punctuation">)</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span> <span class="token keyword">else</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">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheel
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- </span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>script</span><span class="token punctuation">></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><style scoped lang=<span class="token string">"stylus"</span> rel=<span class="token string">"stylesheet/stylus"</span>>
- <span class="token selector"><span class="token comment">/* reset */</span>
- ul</span>
- <span class="token property-declaration"><span class="token property">list-style</span> none</span>
- <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
- <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <span class="token selector">&:before<span class="token punctuation">,</span> &:after</span>
- <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">""</span></span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <span class="token selector">.example-list</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
- <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
- <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>
- <span class="token selector">.example-item</span>
- <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
- <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>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <span class="token selector">&.placeholder</span>
- <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">.picker</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <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>
- <span class="token selector">&.picker-fade-enter<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&.picker-fade-enter-active<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <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>
- <span class="token selector">.picker-panel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
- <span class="token selector">&.picker-move-enter<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">&.picker-move-enter-active<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">.picker-choose</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
- <span class="token selector">.picker-title</span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <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>
- <span class="token selector">.confirm</span>
- <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
- <span class="token selector">.cancel</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
- <span class="token selector">.picker-content</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token selector">.mask-top</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token selector">.mask-bottom</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <span class="token selector">.wheel-wrapper</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <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>
- <span class="token selector">.wheel</span>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <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>
- <span class="token selector">.wheel-scroll</span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <span class="token selector">.wheel-item</span>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">&.wheel-disabled-item</span>
- <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>
- <span class="token selector">.picker-footer</span>
- <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>
- </style></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"><</span>template</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>container<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-list<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-item<span class="token punctuation">"</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">"</span>show<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>open<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-fade<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-move<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-panel<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-choose border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>cancel<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>confirm<span class="token punctuation">"</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">"</span>_confirm<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-title<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>h1</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-content<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-top border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-bottom border-top-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-wrapper<span class="token punctuation">"</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">"</span>wheelWrapper<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel<span class="token punctuation">"</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">"</span>(data, index) in pickerData<span class="token punctuation">"</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">"</span>index<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-scroll<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</span>li</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">"</span>item in data<span class="token punctuation">"</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">"</span>item.value<span class="token punctuation">"</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">"</span>wheel-item<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-footer<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>template</span><span class="token punctuation">></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"><</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">"</span>text/ecmascript-6<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token script"><span class="token language-javascript">
- <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
- <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
- <span class="token keyword">const</span> <span class="token constant">DATA1</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Venomancer'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
- <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>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Spectre'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">3</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Juggernaut'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">4</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Karl'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">5</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Zeus'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">6</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <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>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">7</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Lich'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">8</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Oracle'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">9</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Earthshaker'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">10</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token keyword">const</span> <span class="token constant">DATA2</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Durable'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'a'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Pusher'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'b'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Carry'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'c'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Nuker'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'d'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Support'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'e'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Jungle'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'f'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Escape'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'g'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'Initiator'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'h'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
- <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>
- <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token keyword">return</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
- <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>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <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">=></span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, force it stop at the nearest wheel-item
- * or you can use 'restorePosition' method as the below
- */</span>
- <span class="token comment">// wheel.stop()</span>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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">=></span> <span class="token punctuation">{</span>
- <span class="token keyword">const</span> index <span class="token operator">=</span> currentSelectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
- <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>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- <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">=></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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <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>
- <span class="token keyword">return</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 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>
- <span class="token comment">// waiting for DOM rendered</span>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <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
- <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"><</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>
- <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>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</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_HIDE</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <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>
- <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>
- <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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <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><span class="token punctuation">,</span>
- <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
- <span class="token punctuation">}</span><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">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">=></span> <span class="token punctuation">{</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span> <span class="token keyword">else</span> <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">refresh</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <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>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- </span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>script</span><span class="token punctuation">></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><style scoped lang=<span class="token string">"stylus"</span> rel=<span class="token string">"stylesheet/stylus"</span>>
- <span class="token selector"><span class="token comment">/* reset */</span>
- ul</span>
- <span class="token property-declaration"><span class="token property">list-style</span> none</span>
- <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
- <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <span class="token selector">&:before<span class="token punctuation">,</span> &:after</span>
- <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">""</span></span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <span class="token selector">.example-list</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
- <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
- <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>
- <span class="token selector">.example-item</span>
- <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
- <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>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <span class="token selector">&.placeholder</span>
- <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">.picker</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <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>
- <span class="token selector">&.picker-fade-enter<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&.picker-fade-enter-active<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <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>
- <span class="token selector">.picker-panel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
- <span class="token selector">&.picker-move-enter<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">&.picker-move-enter-active<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">.picker-choose</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
- <span class="token selector">.picker-title</span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <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>
- <span class="token selector">.confirm</span>
- <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
- <span class="token selector">.cancel</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
- <span class="token selector">.picker-content</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token selector">.mask-top</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token selector">.mask-bottom</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <span class="token selector">.wheel-wrapper</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <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>
- <span class="token selector">.wheel</span>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <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>
- <span class="token selector">.wheel-scroll</span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <span class="token selector">.wheel-item</span>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">&.wheel-disabled-item</span>
- <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>
- <span class="token selector">.picker-footer</span>
- <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>
- </style></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"><</span>template</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>container<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-list<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>example-item<span class="token punctuation">"</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">"</span>show<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>open<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{selectedText}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-fade<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-move<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-panel<span class="token punctuation">"</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">"</span>state===1<span class="token punctuation">"</span></span> <span class="token attr-name">@click.stop</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-choose border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>cancel<span class="token punctuation">"</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">"</span>_cancel<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Cancel<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>confirm<span class="token punctuation">"</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">"</span>_confirm<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Confirm<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>span</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-title<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>Title<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>h1</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-content<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-top border-bottom-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>mask-bottom border-top-1px<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-wrapper<span class="token punctuation">"</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">"</span>wheelWrapper<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel<span class="token punctuation">"</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">"</span>(data, index) in pickerData<span class="token punctuation">"</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">"</span>index<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>wheel-scroll<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</span>li</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">"</span>item in data<span class="token punctuation">"</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">"</span>item.value<span class="token punctuation">"</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">"</span>{'wheel-disabled-item':item.disabled}<span class="token punctuation">"</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">"</span>wheel-item<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>{{item.text}}<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>li</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>ul</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"><</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">"</span>picker-footer<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>transition</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>
- <span class="token tag"><span class="token tag"><span class="token punctuation"></</span>template</span><span class="token punctuation">></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"><</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">"</span>text/ecmascript-6<span class="token punctuation">"</span></span><span class="token punctuation">></span></span><span class="token script"><span class="token language-javascript">
- <span class="token keyword">import</span> BScroll <span class="token keyword">from</span> <span class="token string">'@better-scroll/core'</span>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_HIDE</span> <span class="token operator">=</span> <span class="token number">0</span>
- <span class="token keyword">const</span> <span class="token constant">STATE_SHOW</span> <span class="token operator">=</span> <span class="token number">1</span>
- <span class="token keyword">const</span> <span class="token constant">COMPONENT_NAME</span> <span class="token operator">=</span> <span class="token string">'picker'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_SELECT</span> <span class="token operator">=</span> <span class="token string">'select'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CANCEL</span> <span class="token operator">=</span> <span class="token string">'cancel'</span>
- <span class="token keyword">const</span> <span class="token constant">EVENT_CHANGE</span> <span class="token operator">=</span> <span class="token string">'change'</span>
- <span class="token keyword">const</span> <span class="token constant">DATA</span> <span class="token operator">=</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'北京市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'110000'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">"北京市"</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'110100'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'天津市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'120000'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">"天津市"</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'120000'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'河北省'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130000'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'石家庄市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130100'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'唐山市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130200'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'秦皇岛市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130300'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'邯郸市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130400'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'邢台市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130500'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'保定市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130600'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'张家口市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130700'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'承德市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'130800'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'山西省'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140000'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">children</span><span class="token operator">:</span> <span class="token punctuation">[</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'太原市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140100'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'大同市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140200'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'阳泉市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140300'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'长治市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140400'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'晋城市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140500'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'朔州市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140600'</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token punctuation">{</span>
- <span class="token literal-property property">text</span><span class="token operator">:</span> <span class="token string">'晋中市'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'140700'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">]</span>
- <span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token punctuation">{</span>
- <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>
- <span class="token function">data</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token keyword">return</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <span class="token literal-property property">selectedText</span><span class="token operator">:</span> <span class="token string">'open'</span><span class="token punctuation">,</span>
- <span class="token literal-property property">pickerData</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token punctuation">]</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">created</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token comment">// generate data</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token literal-property property">methods</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <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>
- <span class="token keyword">let</span> provinces
- <span class="token keyword">let</span> cities
- <span class="token comment">// first instantiated</span>
- <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>
- 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">=></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>
- 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
- <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>
- <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
- <span class="token comment">// provinces'index changed, refresh cities data</span>
- <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>
- 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
- <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>
- <span class="token comment">// Since cities data changed</span>
- <span class="token comment">// refresh better-scroll to recaculate scrollHeight</span>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">_confirm</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <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">=></span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, force it stop at the nearest wheel-item
- * or you can use 'restorePosition' method as the below
- */</span>
- <span class="token comment">// wheel.stop()</span>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- wheel<span class="token punctuation">.</span><span class="token function">restorePosition</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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">=></span> <span class="token punctuation">{</span>
- <span class="token keyword">const</span> index <span class="token operator">=</span> currentSelectedIndexPair<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
- <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>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">_cancel</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <span class="token comment">/*
- * if bs is scrolling, restore it to the start position
- * it is same with iOS picker and web Select element implementation
- * supported at v2.1.0
- */</span>
- <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">=></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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <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>
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">show</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
- <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>
- <span class="token keyword">return</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 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>
- <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">=></span> <span class="token punctuation">{</span>
- <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>
- <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
- <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"><</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>
- <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>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <span class="token function">hide</span><span class="token punctuation">(</span><span class="token punctuation">)</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_HIDE</span>
- <span class="token punctuation">}</span><span class="token punctuation">,</span>
- <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>
- <span class="token keyword">const</span> wheels <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>wheels
- <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>
- 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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <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><span class="token punctuation">,</span>
- <span class="token literal-property property">probeType</span><span class="token operator">:</span> <span class="token number">3</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token comment">// when any of wheels'scrolling ended , refresh data</span>
- <span class="token keyword">let</span> prevSelectedIndexPair <span class="token operator">=</span> <span class="token keyword">this</span><span class="token punctuation">.</span>selectedIndexPair
- 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">=></span> <span class="token punctuation">{</span>
- <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">=></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>
- <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>
- prevSelectedIndexPair <span class="token operator">=</span> currentSelectedIndexPair
- <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>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token punctuation">}</span> <span class="token keyword">else</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>
- <span class="token punctuation">}</span>
- <span class="token keyword">return</span> wheels<span class="token punctuation">[</span>i<span class="token punctuation">]</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span>
- </span></span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span>script</span><span class="token punctuation">></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><style scoped lang=<span class="token string">"stylus"</span> rel=<span class="token string">"stylesheet/stylus"</span>>
- <span class="token selector"><span class="token comment">/* reset */</span>
- ul</span>
- <span class="token property-declaration"><span class="token property">list-style</span> none</span>
- <span class="token property-declaration"><span class="token property">padding</span> <span class="token number">0</span></span>
- <span class="token selector">.border-bottom-1px<span class="token punctuation">,</span> .border-top-1px</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <span class="token selector">&:before<span class="token punctuation">,</span> &:after</span>
- <span class="token property-declaration"><span class="token property">content</span><span class="token punctuation">:</span> <span class="token string">""</span></span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> block</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <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>
- <span class="token selector">.border-top-1px</span>
- <span class="token selector">&:before</span>
- <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>
- <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>
- <span class="token selector">.border-bottom-1px</span>
- <span class="token selector">&:after</span>
- <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>
- <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>
- <span class="token selector">.example-list</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <span class="token property-declaration"><span class="token property">justify-content</span><span class="token punctuation">:</span> space-between</span>
- <span class="token property-declaration"><span class="token property">flex-wrap</span><span class="token punctuation">:</span> wrap</span>
- <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>
- <span class="token selector">.example-item</span>
- <span class="token property-declaration"><span class="token property">background-color</span> <span class="token color">white</span></span>
- <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>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <span class="token selector">&.placeholder</span>
- <span class="token property-declaration"><span class="token property">visibility</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">height</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">.picker</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> fixed</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">100</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <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>
- <span class="token selector">&.picker-fade-enter<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <span class="token property-declaration"><span class="token property">opacity</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&.picker-fade-enter-active<span class="token punctuation">,</span> &.picker-fade-leave-active</span>
- <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>
- <span class="token selector">.picker-panel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">600</span></span>
- <span class="token property-declaration"><span class="token property">bottom</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">background</span><span class="token punctuation">:</span> <span class="token color">white</span></span>
- <span class="token selector">&.picker-move-enter<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">&.picker-move-enter-active<span class="token punctuation">,</span> &.picker-move-leave-active</span>
- <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>
- <span class="token selector">.picker-choose</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#999</span></span>
- <span class="token selector">.picker-title</span>
- <span class="token property-declaration"><span class="token property">margin</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token property-declaration"><span class="token property">font-weight</span><span class="token punctuation">:</span> normal</span>
- <span class="token property-declaration"><span class="token property">text-align</span><span class="token punctuation">:</span> center</span>
- <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>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">.confirm<span class="token punctuation">,</span> .cancel</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <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>
- <span class="token selector">.confirm</span>
- <span class="token property-declaration"><span class="token property">right</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#007bff</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#5aaaff</span></span>
- <span class="token selector">.cancel</span>
- <span class="token property-declaration"><span class="token property">left</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <span class="token selector">&:active</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#c2c2c2</span></span>
- <span class="token selector">.picker-content</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> relative</span>
- <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>
- <span class="token selector">.mask-top<span class="token punctuation">,</span> .mask-bottom</span>
- <span class="token property-declaration"><span class="token property">z-index</span><span class="token punctuation">:</span> <span class="token number">10</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">pointer-events</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token selector">.mask-top</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <span class="token property-declaration"><span class="token property">top</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <span class="token selector">.mask-bottom</span>
- <span class="token property-declaration"><span class="token property">position</span><span class="token punctuation">:</span> absolute</span>
- <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>
- <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>
- <span class="token selector">.wheel-wrapper</span>
- <span class="token property-declaration"><span class="token property">display</span><span class="token punctuation">:</span> flex</span>
- <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>
- <span class="token selector">.wheel</span>
- <span class="token property-declaration"><span class="token property">flex</span><span class="token punctuation">:</span> <span class="token number">1</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <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>
- <span class="token selector">.wheel-scroll</span>
- <span class="token property-declaration"><span class="token property">padding</span><span class="token punctuation">:</span> <span class="token number">0</span></span>
- <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>
- <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>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <span class="token selector">.wheel-item</span>
- <span class="token property-declaration"><span class="token property">list-style</span><span class="token punctuation">:</span> none</span>
- <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>
- <span class="token property-declaration"><span class="token property">overflow</span><span class="token punctuation">:</span> hidden</span>
- <span class="token property-declaration"><span class="token property">white-space</span><span class="token punctuation">:</span> nowrap</span>
- <span class="token property-declaration"><span class="token property">color</span><span class="token punctuation">:</span> <span class="token hexcode">#333</span></span>
- <span class="token selector">&.wheel-disabled-item</span>
- <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>
- <span class="token selector">.picker-footer</span>
- <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>
- </style></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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- <span class="token comment">// 相当于</span>
- <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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token punctuation">{</span>
- <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>
- <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>
- <span class="token literal-property property">rotate</span><span class="token operator">:</span> <span class="token number">25</span><span class="token punctuation">,</span>
- <span class="token literal-property property">adjustTime</span><span class="token operator">:</span> <span class="token number">400</span><span class="token punctuation">,</span>
- <span class="token literal-property property">selectedIndex</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">,</span>
- <span class="token literal-property property">wheelDisabledItemClass</span><span class="token operator">:</span> <span class="token string">'wheel-disabled-item'</span>
- <span class="token punctuation">}</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- </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>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- <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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- bs<span class="token punctuation">.</span><span class="token function">getSelectedIndex</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
- 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>
- </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>:
- <ul><li><code>{ number } index</code>:选项索引</li> <li><code>{ number } time</code>:动画时长</li> <li><code>{ number } ease<可选></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>
- <span class="token keyword">import</span> Wheel <span class="token keyword">from</span> <span class="token string">'@better-scroll/wheel'</span>
- BScroll<span class="token punctuation">.</span><span class="token function">use</span><span class="token punctuation">(</span>Wheel<span class="token punctuation">)</span>
- <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>
- <span class="token literal-property property">wheel</span><span class="token operator">:</span> <span class="token boolean">true</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- 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">=></span> <span class="token punctuation">{</span>
- console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>index<span class="token punctuation">)</span>
- <span class="token punctuation">}</span><span class="token punctuation">)</span>
- </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">
- ←
- <a href="/docs/zh-CN/plugins/slide.html" class="prev">
- slide
- </a></span> <span class="next"><a href="/docs/zh-CN/plugins/zoom.html">
- zoom
- </a>
- →
- </span></p></div> </main></div><div class="global-ui"><!----></div></div>
- <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>
- </body>
- </html>
|