未验证 提交 b80fae86 编写于 作者: O openharmony_ci 提交者: Gitee

!6121 翻译完成 5137:焦点控制

Merge pull request !6121 from ester.zhou/TR-5137
# Focus Control
> ![icon-note.gif](public_sys-resources/icon-note.gif) **NOTE**
> This attribute is supported since API version 8. Updates will be marked with a superscript to indicate their earliest API version.
> **NOTE**<br>
> The APIs of this module are supported since API version 8. Updates will be marked with a superscript to indicate their earliest API version.
## Required Permissions
......@@ -12,66 +11,57 @@ None
## Attributes
| **Name** | **Type** | **Default Value** | **Description** |
| Name| Type| Default Value| Description|
| -------- | -------- | -------- | -------- |
| focusable | boolean | false | Whether the current component is focusable. |
| focusable | boolean | false | Whether the current component is focusable.|
| tabIndex<sup>9+<sup> | number | 0 | How the current component participates in sequential keyboard navigation.<br>- **tabIndex** >= 0: The component is focusable in sequential keyboard navigation, with its order defined by the value. A component with a larger value is focused after one with a smaller value. If multiple components share the same **tabIndex** value, their focus order follows their position in the component tree.<br>- **tabIndex** < 0 (usually **tabIndex** = -1): The component is focusable, but cannot be reached through sequential keyboard navigation. |
> ![icon-note.gif](public_sys-resources/icon-note.gif) **NOTE**
> The following components support focus control: **&lt;Button&gt;**, **&lt;Text&gt;**, **&lt;Image&gt;**, **&lt;List&gt;**, and **&lt;Grid&gt;**.
> **NOTE**<br>
> The following components support focus control: **\<Button>**, **\<Text>**, **\<Image>**, **\<List>**, and **\<Grid>**.
## Example
```
```ts
// xxx.ets
@Entry
@Component
struct FocusableExample {
@State textOne: string = ''
@State textTwo: string = ''
@State textThree: string = 'The third button cannot be focused'
@State oneButtonColor: string = '#FF0000'
@State twoButtonColor: string = '#FFC0CB'
@State threeButtonColor: string = '#87CEFA'
@State text1: string = 'TabIndex=3'
@State text2: string = 'TabIndex=2'
@State text3: string = 'focusable=false'
@State text4: string = 'TabIndex=-1'
@State text5: string = 'TabIndex=1'
@State text6: string = 'TabIndex=1'
@State text7: string = 'focusable=true'
@State text8: string = 'focusable=true'
build() {
Column({ space:20 }){
Button(this.textOne)
.backgroundColor(this.oneButtonColor)
Button(this.text1) // This component is the fourth component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.focusable(true)
.onFocus(() => {
this.textOne = 'First Button onFocus'
this.oneButtonColor = '#AFEEEE'
})
.onBlur(() => {
this.textOne = 'First Button onBlur'
this.oneButtonColor = '#FFC0CB'
})
Button(this.textTwo)
.backgroundColor(this.twoButtonColor)
.tabIndex(3)
Button(this.text2) // This component is the third component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.focusable(true)
.onFocus(() => {
this.textTwo = 'Second Button onFocus'
this.twoButtonColor = '#AFEEEE'
})
.onBlur(() => {
this.textTwo = 'Second Button onBlur'
this.twoButtonColor = '#FFC0CB'
})
Button(this.textThree)
.backgroundColor(this.threeButtonColor)
.tabIndex(2)
Button(this.text3) // This component is not focusable.
.width(300).height(70).fontColor(Color.Black)
.focusable(false)
.onFocus(() => {
this.textThree = 'Third Button onFocus'
this.threeButtonColor = '#AFEEEE'
})
.onBlur(() => {
this.textThree = 'Third Button onBlur'
this.threeButtonColor = '#FFC0CB'
})
Button(this.text4) // This component is focusable, but cannot be reached through sequential keyboard navigation.
.width(300).height(70).fontColor(Color.Black)
.tabIndex(-1)
Button(this.text5) // This component is the first component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.tabIndex(1)
Button(this.text6) // This component is the second component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.tabIndex(1)
Button(this.text7) // This component is the fifth component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.focusable(true)
Button(this.text8) // This component is the sixth component that is focused when the Tab key is pressed.
.width(300).height(70).fontColor(Color.Black)
.focusable(true)
}.width('100%').margin({ top:20 })
}
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册