美文网首页RN学习日志
React Native - 下拉选择框

React Native - 下拉选择框

作者: Joh蜗牛 | 来源:发表于2019-10-11 14:30 被阅读0次

    前言

    一个下拉框组件:


    react-native-modal-dropdown

    一个react-native的下拉框组件,支持安卓和iOS。

    特点

    • 纯JS组件。
    • 一份代码兼容iOS和Android。
    • 根据按钮位置自动调整下拉框弹出位置。
    • 零配置。 (当然啦,你不传选项的话会显示一个旋转的菊花)
    • 高可定制化。
    • 可通过API代码控制。 (显示、隐藏和选择)

    示例

    在example里可以找到示例代码。

    image image image

    安装

    npm i react-native-modal-dropdown --save
    

    使用

    基本

    先Import组件:

    import ModalDropdown from 'react-native-modal-dropdown';
    
    

    作为组件使用即可:

    <ModalDropdown options={['option 1', 'option 2']}/>
    
    

    自定义

    可以通过传入以下样式属性来自定义样式:

    • style: 改变按钮的样式。
    • textStyle: 改变按钮文字样式。
    • dropdownStyle: 改变下拉框的样式。

    可以通过实现renderRow方法来自定义下拉框中的选项行。

    API

    属性(Props)

    Prop Type Optional Default Description
    disabled bool Yes false 是否禁用组件
    defaultIndex number Yes -1 初始选择。 -1: 未选中。这个只会影响选项展示的高亮与否,不会改变初始的按钮文字。若要改变按钮初始文字请参考defaultValue
    defaultValue string Yes Please select... 按钮初始文字。
    options arrayOf(string) Yes 选项。 null/undefined则下拉框会显示一个加载图标。
    style object Yes 按钮样式。
    textStyle object Yes 按钮文字样式。
    dropdownStyle object Yes 下拉框样式。
    renderRow func Yes 自定义选项行的渲染。null/undefined会使用默认的行渲染。
    onDropdownWillShow func Yes 下拉框显示前触发。 若实现此方法并返回false可以阻止显示。
    onDropdownWillHide func Yes 下拉框隐藏前触发。若实现此方法并返回false可以阻止隐藏。
    onSelect func Yes 选择选项时触发并返回indexvalue若实现此方法并返回false可以阻止选择。

    方法

    Method Description
    updatePosition() 手动更新下拉框位置。如果控件放在scroll view里面,需要在scrollViewonScroll方法中调用此方法。
    show() 显示下拉框。不会触发onDropdownWillShow
    hide() 隐藏下拉框。不会触发onDropdownWillHide
    select(idx) 选择给定索引(idx)的选项。不会触发onSelect

    相关文章

      网友评论

        本文标题:React Native - 下拉选择框

        本文链接:https://www.haomeiwen.com/subject/tzljuctx.html