Project Icon

menu

React Native跨平台菜单组件 适用Android和iOS

@react-native-menu/menu是一款React Native跨平台菜单组件,为Android和iOS提供统一的菜单解决方案。组件在Android上使用PopupMenu,iOS 14+使用UIMenu,低版本iOS则采用ActionSheet。支持自定义菜单标题、操作项、图标和子菜单,提供多样化样式选项和回调功能。安装简便,使用灵活,有助于开发者快速实现可定制化的菜单功能。

@react-native-menu/menu

支持Android、iOSGithub Action 徽章 npm

适用于react-native的Android PopupMenu和iOS14+ UIMenu组件。 在低于iOS14的版本上回退使用ActionSheet。

AndroidiOS 14+iOS 13

安装

通过npm:

npm install @react-native-menu/menu

通过yarn:

yarn add @react-native-menu/menu

在React Native 0.63及以上版本的iOS上安装

有一个问题(https://github.com/facebook/react-native/issues/29246)导致包含此模块的项目在React Native 0.63及以上版本上构建失败。 这个问题可能会在未来的react native版本中修复。 作为临时解决方案,在[YourPrject].xcodeproj中查找LIBRARY_SEARCH_PATHS下包含"\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"",的行,并将swift-5.0改为swift-5.3

链接

在构建应用时,该包会自动链接。你只需要执行:

npx pod-install

使用

import { MenuView } from '@react-native-menu/menu';

// ...

const App = () => {
  return (
    <View style={styles.container}>
      <MenuView
        title="菜单标题"
        onPressAction={({ nativeEvent }) => {
          console.warn(JSON.stringify(nativeEvent));
        }}
        actions={[
          {
            id: 'add',
            title: '添加',
            titleColor: '#2367A2',
            image: Platform.select({
              ios: 'plus',
              android: 'ic_menu_add',
            }),
            imageColor: '#2367A2',
            subactions: [
              {
                id: 'nested1',
                title: '嵌套操作',
                titleColor: 'rgba(250,180,100,0.5)',
                subtitle: '状态为混合',
                image: Platform.select({
                  ios: 'heart.fill',
                  android: 'ic_menu_today',
                }),
                imageColor: 'rgba(100,200,250,0.3)',
                state: 'mixed',
              },
              {
                id: 'nestedDestructive',
                title: '破坏性操作',
                attributes: {
                  destructive: true,
                },
                image: Platform.select({
                  ios: 'trash',
                  android: 'ic_menu_delete',
                }),
              },
            ],
          },
          {
            id: 'share',
            title: '分享操作',
            titleColor: '#46F289',
            subtitle: '在社交网络上分享',
            image: Platform.select({
              ios: 'square.and.arrow.up',
              android: 'ic_menu_share',
            }),
            imageColor: '#46F289',
            state: 'on',
          },
          {
            id: 'destructive',
            title: '破坏性操作',
            attributes: {
              destructive: true,
            },
            image: Platform.select({
              ios: 'trash',
              android: 'ic_menu_delete',
            }),
          },
        ]}
        shouldOpenOnLongPress={false}
      >
        <View style={styles.button}>
          <Text style={styles.buttonText}>测试</Text>
        </View>
      </MenuView>
    </View>
  );
};

声明式用法

也可以以更加React式的声明方式获取action。参考react-to-imperative包,并查看这里的示例。

参考

属性

title(仅iOS)

菜单的标题。

类型是否必需
string

isAnchoredToRight(仅Android)

决定菜单是否应锚定在父视图的右上角或左上角的布尔值。

类型是否必需
boolean

shouldOpenOnLongPress

决定菜单是在长按还是普通按压后打开的布尔值。

类型是否必需
boolean

actions

要在菜单中显示的操作。

类型是否必需
MenuAction[]

themeVariant(仅iOS)

用于覆盖菜单主题的字符串。如果你想在整个应用中统一控制主题,请参考这个包

类型是否必需
enum('light', 'dark')

MenuAction

表示菜单操作的对象。

export type MenuAction = {
  /**
   * 菜单操作的标识符。
   * 当菜单被选中时,将返回此id中设置的值。
   */
  id?: string;
  /**
   * 操作的标题。
   */
  title: string;
  /**
   * (仅限Android)
   * 操作的标题颜色。
   * @platform Android
   */
  titleColor?: number | ColorValue;
  /**
   * (仅限iOS14+)
   * 解释操作目的的详细标题。
   * @platform iOS
   */
  subtitle?: string;
  /**
   * 指示操作样式的属性。
   */
  attributes?: MenuAttributes;
  /**
   * (仅限iOS14+)
   * 操作的状态。
   * @platform iOS
   */
  state?: MenuState;
  /**
   * (仅限Android和iOS13+)
   * - 操作的图像。
   * - 允许使用项目中包含的图标名称或系统(Android)资源可绘制图标和
   * SF Symbol(iOS)
   * @example // (iOS)
   * image="plus"
   * @example // (Android)
   * image="ic_menu_add"
   */
  image?: string;
  /**
   * (仅限Android和iOS13+)
   * - 操作的图像颜色。
   */
  imageColor?: number | ColorValue;
  /**
   * (仅限Android和iOS14+)
   * - 要在子菜单中显示的操作
   * - 在Android上不支持在子菜单项中嵌套下一级子菜单
   */
  subactions?: MenuAction[];
};

MenuAttributes

指示操作样式的属性。

type MenuAttributes = {
  /**
   * 指示破坏性样式的属性。
   */
  destructive?: boolean;
  /**
   * 指示禁用样式的属性。
   */
  disabled?: boolean;
  /**
   * 指示隐藏样式的属性。
   */
  hidden?: boolean;
};

MenuState

操作的状态。

/**
 * 操作的状态。
 * - off: 表示菜单元素处于"关闭"状态的常量。
 * - on: 表示菜单元素处于"开启"状态的常量。
 * - mixed: 表示菜单元素处于"混合"状态的常量。
 */
type MenuState = 'off' | 'on' | 'mixed';

onPressAction

选择菜单项时将调用的回调函数。 它将包含给定操作的id。

类型是否必需
({nativeEvent}) => void

贡献

查看贡献指南了解如何为该仓库做出贡献以及开发工作流程。

许可

MIT

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号