当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Swift Never accessibilityRotor(_:entries:entryLabel:)用法及代码示例


用法一

实例方法

accessibilityRotor(_:entries:entryLabel:)

使用指定的 user-visible 标签和条目创建辅助函数转子。

声明

func accessibilityRotor<EntryModel>(
    _ rotorLabel: Text,
    entries: [EntryModel],
    entryLabel: KeyPath<EntryModel, String>
) -> some View where EntryModel : Identifiable

参数

rotorLabel

向用户标识此转子的本地化标签。

entries

一组可识别的值,将用于生成转子的条目。 Identifiable 值的标识符必须与 ForEach 中的标识符或 ScrollView 中的显式 id 调用中的标识符匹配。当用户从该转子导航到条目时,SwiftUI 将根据需要自动将它们滚动到适当的位置。

entryLabel

Identifiable 类型上的键路径,可用于为每个转子条目获取 user-visible 标签。当用户打开转子的条目列表时,这在 macOS 上使用。

详述

辅助函数转子是辅助函数用户快速导航到用户接口的特定元素以及这些元素中的特定文本范围的快捷方式。

使用此修饰符需要将转子附加到 ScrollView 或直接在 ScrollView 内的辅助函数元素,例如 ForEach

在以下示例中,消息应用程序创建了一个转子,允许用户导航到特定于来自 VIP 的消息。


// `messages` is a list of `Identifiable` `Message`s that have a
// `subject`.
// `vipMessages` is a filtered version of that list containing only
// messages from VIPs.


ScrollView {
    LazyVStack {
        ForEach(messages) { message in
            MessageView(message)
        }
    }
}
.accessibilityElement(children: .contain)
.accessibilityRotor("VIPs", entries: vipMessages, label: \.subject)

可用版本

iOS 15.0+, iPadOS 15.0+, macOS 12.0+, Mac Catalyst 15.0+, tvOS 15.0+, watchOS 8.0+

用法二

实例方法

accessibilityRotor(_:entries:entryLabel:)

创建一个可访问性转子来替换指定的系统提供的转子。

声明

func accessibilityRotor<EntryModel>(
    _ systemRotor: AccessibilitySystemRotor,
    entries: [EntryModel],
    entryLabel: KeyPath<EntryModel, String>
) -> some View where EntryModel : Identifiable

参数

systemRotor

将被此自定义转子覆盖的系统提供的转子。

entries

一组可识别的值,将用于生成转子的条目。 Identifiable 值的标识符必须与 ForEach 中的标识符或 ScrollView 中的显式 id 调用中的标识符匹配。当用户从该转子导航到条目时,SwiftUI 将根据需要自动将它们滚动到适当的位置。

entryLabel

Identifiable 类型上的键路径,可用于为每个转子条目获取 user-visible 标签。当用户打开转子的条目列表时,这在 macOS 上使用。

详述

辅助函数转子是辅助函数用户快速导航到用户接口的特定元素以及这些元素中的特定文本范围的快捷方式。

使用此修饰符需要将转子附加到 ScrollView 或直接在 ScrollView 内的辅助函数元素,例如 ForEach

在以下示例中,消息应用程序创建了一个转子,允许用户导航到其垂直消息堆栈中的标题。


// `messageListItems` is a list of `Identifiable` `MessageListItem`s
// that are either a `Message` or a heading, containing a `subject`.
// `headingMessageListItems` is a filtered list of
// `messageListItems` containing just the headings.
ScrollView {
    LazyVStack {
        ForEach(messageListItems) { messageListItem in
            switch messageListItem {
                case .heading(let subject):
                    Text(subject)
                case .message(let message):
                    MessageView(message)
            }
        }
    }
}
.accessibilityElement(children: .contain)
.accessibilityRotor(
    .heading, entries: headingMessageListItems, label: \.subject)

可用版本

iOS 15.0+, iPadOS 15.0+, macOS 12.0+, Mac Catalyst 15.0+, tvOS 15.0+, watchOS 8.0+

用法三

实例方法

accessibilityRotor(_:entries:entryLabel:)

使用指定的 user-visible 标签和条目创建辅助函数转子。

声明

func accessibilityRotor<EntryModel>(
    _ rotorLabelKey: LocalizedStringKey,
    entries: [EntryModel],
    entryLabel: KeyPath<EntryModel, String>
) -> some View where EntryModel : Identifiable

参数

rotorLabelKey

向用户标识此转子的本地化标签。

entries

一组可识别的值,将用于生成转子的条目。 Identifiable 值的标识符必须与 ForEach 中的标识符或 ScrollView 中的显式 id 调用中的标识符匹配。当用户从该转子导航到条目时,SwiftUI 将根据需要自动将它们滚动到适当的位置。

entryLabel

Identifiable 类型上的键路径,可用于为每个转子条目获取 user-visible 标签。当用户打开转子的条目列表时,这在 macOS 上使用。

详述

辅助函数转子是辅助函数用户快速导航到用户接口的特定元素以及这些元素中的特定文本范围的快捷方式。

使用此修饰符需要将转子附加到 ScrollView 或直接在 ScrollView 内的辅助函数元素,例如 ForEach

在以下示例中,消息应用程序创建了一个转子,允许用户导航到特定于来自 VIP 的消息。


// `messages` is a list of `Identifiable` `Message`s that have a
// `subject`.
// `vipMessages` is a filtered version of that list containing only
// messages from VIPs.


ScrollView {
    LazyVStack {
        ForEach(messages) { message in
            MessageView(message)
        }
    }
}
.accessibilityElement(children: .contain)
.accessibilityRotor("VIPs", entries: vipMessages,
    entryLabel: \.subject)

可用版本

iOS 15.0+, iPadOS 15.0+, macOS 12.0+, Mac Catalyst 15.0+, tvOS 15.0+, watchOS 8.0+

用法四

实例方法

accessibilityRotor(_:entries:entryLabel:)

使用指定的 user-visible 标签和条目创建辅助函数转子。

声明

func accessibilityRotor<L, EntryModel>(
    _ rotorLabel: L,
    entries: [EntryModel],
    entryLabel: KeyPath<EntryModel, String>
) -> some View where L : StringProtocol, EntryModel : Identifiable

参数

rotorLabel

向用户标识此转子的本地化标签。

entries

一组可识别的值,将用于生成转子的条目。 Identifiable 值的标识符必须与 ForEach 中的标识符或 ScrollView 中的显式 id 调用中的标识符匹配。当用户从该转子导航到条目时,SwiftUI 将根据需要自动将它们滚动到适当的位置。

entry

Identifiable 类型上的键路径,可用于为每个转子条目获取 user-visible 标签。当用户打开转子的条目列表时,这在 macOS 上使用。

详述

辅助函数转子是辅助函数用户快速导航到用户接口的特定元素以及这些元素中的特定文本范围的快捷方式。

使用此修饰符需要将转子附加到 ScrollView 或直接在 ScrollView 内的辅助函数元素,例如 ForEach

在以下示例中,消息应用程序创建了一个转子,允许用户导航到特定于来自 VIP 的消息。


// `messages` is a list of `Identifiable` `Message`s that have a
// `subject`.
// `vipMesages` is a filtered version of that list containing only
// messages from VIPs.


ScrollView {
    LazyVStack {
        ForEach(messages) { message in
            MessageView(message)
        }
    }
}
.accessibilityElement(children: .contain)
.accessibilityRotor("VIPs", entries: vipMessages, label: \.subject)

可用版本

iOS 15.0+, iPadOS 15.0+, macOS 12.0+, Mac Catalyst 15.0+, tvOS 15.0+, watchOS 8.0+

相关用法


注:本文由纯净天空筛选整理自apple.com大神的英文原创作品 Never accessibilityRotor(_:entries:entryLabel:)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。