1# stack
2
3堆叠容器,子组件按照顺序依次入栈,后一个子组件覆盖前一个子组件。
4
5> **说明:**
6>
7> 该组件从从API version 4 开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
8
9
10## 子组件
11
12支持。
13
14
15## 属性
16
17| 名称    | 类型     | 默认值  | 必填   | 描述                                       |
18| ----- | ------ | ---- | ---- | ---------------------------------------- |
19| id    | string | -    | 否    | 组件的唯一标识。                                 |
20| style | string | -    | 否    | 组件的样式声明。                                 |
21| class | string | -    | 否    | 组件的样式类,用于引用样式表。                          |
22| ref   | string | -    | 否    | 用来指定指向子元素的引用信息,该引用将注册到父组件的$refs 属性对象上。 |
23
24
25## 事件
26
27| 名称                 | 参数                                | 描述          |
28| ------------------ | --------------------------------- | ----------- |
29| click              | -                                 | 点击动作触发该事件。  |
30| longpress          | -                                 | 长按动作触发该事件。  |
31| swipe<sup>5+</sup> | [SwipeEvent](js-lite-common-events.md) | 组件上快速滑动后触发。 |
32
33
34## 样式
35
36| 名称                                 | 类型                                       | 默认值   | 必填   | 描述                                       |
37| ---------------------------------- | ---------------------------------------- | ----- | ---- | ---------------------------------------- |
38| width                              | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | -     | 否    | 设置组件自身的宽度。<br/><br/>未设置时组件宽度默认为0。        |
39| height                             | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | -     | 否    | 设置组件自身的高度。<br/><br/>未设置时组件高度默认为0。        |
40| padding                            | &lt;length&gt;                           | 0     | 否    | 使用简写属性设置所有的内边距属性。<br/>&nbsp;&nbsp;该属性可以有1到4个值:<br/>-&nbsp;指定一个值时,该值指定四个边的内边距。<br/>-&nbsp;指定两个值时,第一个值指定上下两边的内边距,第二个指定左右两边的内边距。<br/>-&nbsp;指定三个值时,第一个指定上边的内边距,第二个指定左右两边的内边距,第三个指定下边的内边距。<br/>-&nbsp;指定四个值时分别为上、右、下、左边的内边距(顺时针顺序)。 |
41| padding-[left\|top\|right\|bottom] | &lt;length&gt;                           | 0     | 否    | 设置左、上、右、下内边距属性。                          |
42| margin                             | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | 0     | 否    | 使用简写属性设置所有的外边距属性,该属性可以有1到4个值。<br/>-&nbsp;只有一个值时,这个值会被指定给全部的四个边。<br/>-&nbsp;两个值时,第一个值被匹配给上和下,第二个值被匹配给左和右。<br/>-&nbsp;三个值时,第一个值被匹配给上,&nbsp;第二个值被匹配给左和右,第三个值被匹配给下。<br/>-&nbsp;四个值时,会依次按上、右、下、左的顺序匹配&nbsp;(即顺时针顺序)。 |
43| margin-[left\|top\|right\|bottom]  | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>5+</sup> | 0     | 否    | 设置左、上、右、下外边距属性。                          |
44| border-width                       | &lt;length&gt;                           | 0     | 否    | 使用简写属性设置元素的所有边框宽度。                       |
45| border-color                       | &lt;color&gt;                            | black | 否    | 使用简写属性设置元素的所有边框颜色。                       |
46| border-radius                      | &lt;length&gt;                           | -     | 否    | border-radius属性是设置元素的外边框圆角半径。            |
47| background-color                   | &lt;color&gt;                            | -     | 否    | 设置背景颜色。                                  |
48| opacity<sup>5+</sup>               | number                                   | 1     | 否    | 元素的透明度,取值范围为0到1,1表示为不透明,0表示为完全透明。        |
49| display                            | string                                   | flex  | 否    | 确定一个元素所产生的框的类型,可选值为:<br/>-&nbsp;flex:弹性布局。<br/>-&nbsp;none:不渲染此元素。 |
50| [left\|top]                        | &lt;length&gt;&nbsp;\|&nbsp;&lt;percentage&gt;<sup>6+</sup> | -     | 否    | left\|top确定元素的偏移位置。<br/>-&nbsp;left属性规定元素的左边缘。该属性定义了定位元素左外边距边界与其包含块左边界之间的偏移。<br/>-&nbsp;top属性规定元素的顶部边缘。该属性定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移。 |
51
52>  **说明:**
53>
54> 由于绝对定位不支持设置百分比,所以也不支持stack组件的子组件上设置margin。
55
56
57## 示例
58
59
60```html
61<!-- xxx.hml -->
62<stack class="stack-parent">
63  <div class="back-child bd-radius"></div>
64  <div class="positioned-child bd-radius"></div>
65  <div class="front-child bd-radius"></div>
66</stack>
67```
68
69
70```css
71/* xxx.css */
72.stack-parent {
73  width: 400px;
74  height: 400px;
75  background-color: #ffffff;
76  border-width: 1px;
77  border-style: solid;
78}
79.back-child {
80  width: 300px;
81  height: 300px;
82  background-color: #3f56ea;
83}
84.front-child {
85  width: 100px;
86  height: 100px;
87  background-color: #00bfc9;
88}
89.positioned-child {
90  width: 100px;
91  height: 100px;
92  left: 50px;
93  top: 50px;
94  background-color: #47cc47;
95}
96.bd-radius {
97  border-radius: 16px;
98}
99```
100
101![zh-cn_image_0000001380789188](figures/zh-cn_image_0000001380789188.png)
102