schangxiang@126.com
2025-06-13 f10d68fe7b934ba7ad8e8393f36f20878ed8155d
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>