90 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
| <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>
 |