• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# popup
2<!--Kit: ArkUI-->
3<!--Subsystem: ArkUI-->
4<!--Owner: @liyi0309-->
5<!--Designer: @liyi0309-->
6<!--Tester: @lxl007-->
7<!--Adviser: @HelloCrease-->
8
9>  **说明:**
10> 从API version 4开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
11
12气泡指示。给控件绑定气泡弹窗,并在点击控件或者调用气泡弹窗显示方法后弹出相应的气泡提示来引导用户进行操作。
13
14## 权限列表
15
1617
18
19## 子组件
20
21支持单个子组件节点<sup>5+</sup>。
22
23
24## 属性
25
26除支持[通用属性](js-components-common-attributes.md)外,还支持如下属性:
27
28| 名称 | 类型 | 默认值 | 必填 | 描述 |
29| -------- | -------- | -------- | -------- | -------- |
30| target | string | - | 是 | popup绑定目标元素的id属性值,不支持动态切换。 |
31| placement | string | bottom | 否 | popup相对于目标元素的位置。可选值为:<br/>-&nbsp;left:位于目标元素左边;<br/>-&nbsp;right:位于目标元素右边;<br/>-&nbsp;top:位于目标元素上边;<br/>-&nbsp;bottom:位于目标元素下边;<br/>-&nbsp;topLeft:位于目标元素左上角;<br/>-&nbsp;topRight:位于目标元素右上角;<br/>-&nbsp;bottomLeft:位于目标元素左下角;<br/>-&nbsp;bottomRight:位于目标元素右下角。 |
32| keepalive<sup>5+</sup> | boolean | false | 否 | 设置当前popup是否需要保留。设置为true时,点击屏幕区域或者页面切换气泡不会消失,需调用气泡组件的hide方法才可让气泡消失;设置为false时,点击屏幕区域或者页面切换气泡会自动消失。 |
33| clickable<sup>5+</sup> | boolean | true | 否 | popup是否支持点击目标元素弹窗,当设置为false时,只支持方法调用显示弹窗。 |
34| arrowoffset<sup>5+</sup> | &lt;length&gt; | 0 | 否 | popup箭头在弹窗处的偏移,默认居中,正值按照语言方向进行偏移,负值相反。 |
35
36>  **说明:**
37>
38> - 不支持focusable属性。
39
40
41## 样式
42
43除支持[通用样式](js-components-common-styles.md)外,还支持如下样式:
44
45| 名称 | 类型 | 默认值 | 必填 | 描述 |
46| -------- | -------- | -------- | -------- | -------- |
47| mask-color | &lt;color&gt; | - | 否 | 遮罩层的颜色,默认值为全透明。 |
48
49>  **说明:**
50>
51> - 不支持position相关样式。
52
53
54## 事件
55
56除支持[通用事件](js-components-common-events.md)外,还支持如下事件:
57
58| 名称 | 参数 | 描述 |
59| -------- | -------- | -------- |
60| visibilitychange | {&nbsp;visibility:&nbsp;boolean&nbsp;} | 当气泡弹出和消失时会触发该回调函数。 |
61
62
63## 方法
64
65仅支持如下方法:
66
67| 名称 | 参数 | 描述 |
68| -------- | -------- | -------- |
69| show<sup>5+</sup> | - | 弹出气泡提示。 |
70| hide<sup>5+</sup> | - | 隐藏气泡提示。 |
71
72>  **说明:**
73> 1. popup气泡弹窗属性、样式均不支持动态更新。
74>
75> 2. popup气泡弹窗的margin样式是相对于target元素进行生效的,如popup在target元素下方,此时只生效margin-top样式,popup在target元素左上方,此时只生效margin-bottom和margin-right样式。
76>
77> 3. popup的border四边样式需一致,若四边设置不一致且圆角为零,则按左、上、右、下的顺序取第一个被设置的样式,否则border不生效。
78>
79> 4. popup的target组件的click事件不生效。
80
81
82## 示例
83
84```html
85<!-- xxx.hml -->
86<div class="container">
87  <text id="text">Click to show the pop-up</text>
88  <!-- popup supports single child of any type5+ -->
89  <popup id="popup" class="popup" target="text" placement="top" keepalive="true" clickable="true"
90    arrowoffset="100px" onvisibilitychange="visibilitychange" onclick="hidepopup">
91    <text class="text">Text content of the pop-up</text>
92  </popup>
93  <button class="button" onclick="showpopup">Click to show the pop-up</button>
94</div>
95```
96
97```css
98/* xxx.css */
99.container {
100  flex-direction: column;
101  align-items: center;
102  padding-top: 200px;
103  padding-left: 200px;
104}
105.popup {
106  mask-color: gray;
107}
108.text {
109  color: white;
110}
111.button {
112  width: 220px;
113  height: 100px;
114  margin-top: 50px;
115}
116```
117
118```js
119// xxx.js
120import promptAction from '@ohos.promptAction'
121export default {
122  visibilitychange(e) {
123    promptAction.showToast({
124      message: 'visibility change visibility: ' + e.visibility,
125        duration: 3000
126    });
127  },
128  showpopup() {
129    this.$element("popup").show();
130  },
131  hidepopup() {
132    this.$element("popup").hide();
133  }
134}
135```
136
137![zh-cn_image_0000001178886129](figures/zh-cn_image_0000001178886129.png)
138