| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
 | | <template> |  |     <!-- 支付宝小程序使用$u.getRect()获取组件的根元素尺寸,所以在外面套一个"壳" --> |  |     <view> |  |         <view class="u-index-anchor-wrapper" :id="$u.guid()" :style="[wrapperStyle]"> |  |             <view class="u-index-anchor " :class="[active ? 'u-index-anchor--active' : '']" :style="[customAnchorStyle]"> |  |                 <slot v-if="useSlot" /> |  |                 <block v-else> |  |                     <text>{{ index }}</text> |  |                 </block> |  |             </view> |  |         </view> |  |     </view> |  | </template> |  |   |  | <script> |  |     /** |  |      * indexAnchor 索引列表锚点 |  |      * @description 通过折叠面板收纳内容区域,搭配<u-index-anchor>使用 |  |      * @tutorial https://www.uviewui.com/components/indexList.html#indexanchor-props |  |      * @property {Boolean} use-slot 是否使用自定义内容的插槽(默认false) |  |      * @property {String Number} index 索引字符,如果定义了use-slot,此参数自动失效 |  |      * @property {Object} custStyle 自定义样式,对象形式,如"{color: 'red'}" |  |      * @event {Function} default 锚点位置显示内容,默认为索引字符 |  |      * @example <u-index-anchor :index="item" /> |  |      */ |  |     export default { |  |         name: "u-index-anchor", |  |         props: { |  |             useSlot: { |  |                 type: Boolean, |  |                 default: false |  |             }, |  |             index: { |  |                 type: String, |  |                 default: '' |  |             }, |  |             customStyle: { |  |                 type: Object, |  |                 default () { |  |                     return {} |  |                 } |  |             } |  |         }, |  |         data() { |  |             return { |  |                 active: false, |  |                 wrapperStyle: {}, |  |                 anchorStyle: {} |  |             } |  |         }, |  |         created() { |  |             this.parent = false; |  |         }, |  |         mounted() { |  |             this.parent = this.$u.$parent.call(this, 'u-index-list'); |  |             if(this.parent) { |  |                 this.parent.children.push(this); |  |                 this.parent.updateData(); |  |             } |  |         }, |  |         computed: { |  |             customAnchorStyle() { |  |                 return Object.assign(this.anchorStyle, this.customStyle); |  |             } |  |         } |  |     } |  | </script> |  |   |  | <style lang="scss" scoped> |  |     @import "../../libs/css/style.components.scss"; |  |      |  |     .u-index-anchor { |  |         box-sizing: border-box; |  |         padding: 14rpx 24rpx; |  |         color: #606266; |  |         width: 100%; |  |         font-weight: 500; |  |         font-size: 28rpx; |  |         line-height: 1.2; |  |         background-color: rgb(245, 245, 245); |  |     } |  |   |  |     .u-index-anchor--active { |  |         right: 0; |  |         left: 0; |  |         color: #2979ff; |  |         background-color: #fff; |  |     } |  | </style> | 
 |