手写滚动选择器 picker的功能

picker滚动选择器(下简称picker)是微信小程序自带的组件,无需引入任何文件,只要在适当的位置放入picker代码点击后就可以从底部弹起的滚动选择器。我们接下来就要实现类似的功能,做到我们自己的需求.

功能要求:

  1. 实现列表的滚动,列表中间的元素边框颜色加重.
  2. 滚动的时候默认选中间位置的元素
  3. 点确定选中并打印出来,
  4. 等等等功能  ,具体你们自己去看吧

首先我们搭建一下页面结构.

html

<template>
	<view class="container">
		<button @tap="showModal = !showModal">显示</button>
		<view v-if="showModal" class="modal">
			<view class="content">
				<scroll-view class="picker" scroll-y="true" @scroll="onScroll">
					<view class="picker-spacer"></view>
					<view v-for="(item, i) in array" :key="i" class="picker-item aaa" :class="{ 'picker-item-selected': selectedIndex === i }">
						{{ item }}
					</view>
					<view class="picker-spacer"></view>
				</scroll-view>
				<view class="picker-highlight"></view>
				<view class="buttons">
					<button class="qv" @click="cancel">取消</button>
					<button class="qd" @click="confirm">确定</button>
				</view>
			</view>
		</view>
	</view>
</template>

接下来我们定义一下css

<style lang="scss">
.container {
	width: 100%;
}

.modal {
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	display: flex;
	justify-content: center;
	align-items: center;
}

.content {
	position: fixed;
	bottom: 90upx;
	width: 100%;
	background-color: white;
}

.picker {
	position: relative;
	height: 200px;
	overflow: scroll;
}

.picker-item {
	height: 40px;
	line-height: 40px;
	text-align: center;
}
.aaa {
	border-top: 1px solid #f8f8f8;
	border-bottom: 1px solid #f8f8f8;
}
.picker-item-selected {
	width: 100%;
	border-top: 1px solid #b0b0b0;
	border-bottom: 1px solid #b0b0b0;
}

.picker-spacer {
	height: 80px;
}

.picker-highlight {
	position: absolute;
	top: 80px;
	width: 100%;
	height: 40px;
	// border-top: 1px solid black;
	// border-bottom: 1px solid black;
	pointer-events: none;
}

.buttons {
	display: flex;
	justify-content: space-between;
}

.qv {
	text-align: center;
	line-height: 80upx;
	height: 80upx;
	width: 180upx;
	background-color: #b0b0b0;
}

.qd {
	text-align: center;
	line-height: 80upx;
	height: 80upx;
	width: 180upx;
	background-color: rgba(198, 150, 79, 1);
}
</style>

逻辑部分

<script>
export default {
	data() {
		return {
			showModal: false,
			array: ['选项1', '选项2', '选项3', '选项4', '选项5', '选项6'],
			selectedIndex: 0
		};
	},
	methods: {
		onScroll(e) {
			const itemHeight = 40;
			this.selectedIndex = Math.round(e.target.scrollTop / itemHeight);
		},
		cancel() {
			this.showModal = false;
		},
		confirm() {
			this.showModal = false;
			console.log('你选择了:' + this.array[this.selectedIndex]);
		}
	}
};
</script>

直接复制代码就能用  不用谢我,个人瞎写的


  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来为你介绍一下如何滚动日期选择。我们可以利用Vue框架中的指令来实现这个效果。 首先,我们需要在HTML中创建一个容来放置日期选择组件,如下所示: ```html <div class="date-picker" v-click-outside="hidePicker"> <input type="text" v-model="selectedDate" @click="showPicker" readonly> <div class="picker-container" v-show="show"> <div class="picker-header"> <button @click="prevMonth"><</button> <span>{{ currentYear }}年{{ currentMonth }}月</span> <button @click="nextMonth">></button> </div> <div class="picker-body"> <div class="picker-row" v-for="week in weeks"> <div class="picker-cell" v-for="day in week" :class="{ 'is-today': isToday(day), 'is-selected': isSelected(day) }" @click="selectDate(day)"> {{ day }} </div> </div> </div> </div> </div> ``` 在上面的代码中,我们创建了一个`date-picker`的容,其中包含一个`input`输入框和一个日期选择的弹出框。输入框中绑定了`selectedDate`变量,用来显示当前选择的日期。日期选择的弹出框使用了Vue的指令`v-show`来控制其显示和隐藏状态。 接下来,我们需要在Vue组件的`data`属性中定义一些变量,如下所示: ```javascript data() { return { selectedDate: '', show: false, currentYear: new Date().getFullYear(), currentMonth: new Date().getMonth() + 1, currentDate: new Date().getDate(), weeks: [], days: [] } } ``` 在上面的代码中,我们定义了一些重要的变量。`selectedDate`用来保存用户选择的日期,`show`用来控制日期选择的显示和隐藏状态,`currentYear`、`currentMonth`和`currentDate`用来记录当前日期,`weeks`和`days`用来保存渲染日期选择所需要的数据。 接下来,我们需要在Vue组件的`mounted`钩子函数中初始化日期选择的数据,如下所示: ```javascript mounted() { // 初始化日期选择数据 this.initWeeks() this.initDays() } ``` 在上面的代码中,我们调用了`initWeeks`和`initDays`两个函数来初始化日期选择的数据。 `initWeeks`函数用来初始化日期选择的星期数据,如下所示: ```javascript initWeeks() { this.weeks = [ ['日', '一', '二', '三', '四', '五', '六'] ] } ``` 在上面的代码中,我们定义了一个数组`weeks`,其中包含了一周内的所有日期。 `initDays`函数用来初始化日期选择的日期数据,如下所示: ```javascript initDays() { const firstDay = new Date(this.currentYear, this.currentMonth - 1, 1).getDay() // 当月第一天是星期几 const lastDay = new Date(this.currentYear, this.currentMonth, 0).getDate() // 当月最后一天是几号 let days = [] let day = 1 for (let i = 0; i < 6; i++) { let week = [] for (let j = 0; j < 7; j++) { if (day > lastDay) { break } if (i === 0 && j < firstDay) { week.push('') } else { week.push(day++) } } days.push(week) } this.days = days } ``` 在上面的代码中,我们使用了`Date`对象来获取当前日期所在月份的第一天和最后一天,然后使用一个嵌套循环来遍历当前月份的所有日期,并将它们保存在一个二维数组中。 接下来,我们需要在Vue组件中定义一些方法来处理用户的交互操作,如下所示: ```javascript methods: { // 显示日期选择 showPicker() { this.show = true }, // 隐藏日期选择 hidePicker() { this.show = false }, // 上一个月 prevMonth() { if (this.currentMonth === 1) { this.currentYear -= 1 this.currentMonth = 12 } else { this.currentMonth -= 1 } this.initDays() }, // 下一个月 nextMonth() { if (this.currentMonth === 12) { this.currentYear += 1 this.currentMonth = 1 } else { this.currentMonth += 1 } this.initDays() }, // 选择日期 selectDate(day) { if (day === '') { return } this.selectedDate = `${this.currentYear}-${this.currentMonth}-${day}` this.hidePicker() }, // 判断是否为今天 isToday(day) { return this.currentYear === new Date().getFullYear() && this.currentMonth === new Date().getMonth() + 1 && day === new Date().getDate() }, // 判断是否为选择状态 isSelected(day) { return this.selectedDate === `${this.currentYear}-${this.currentMonth}-${day}` } } ``` 在上面的代码中,我们定义了一些方法来处理用户的交互操作。`showPicker`和`hidePicker`方法用来显示和隐藏日期选择的弹出框。`prevMonth`和`nextMonth`方法用来切换日期选择的月份。`selectDate`方法用来选择日期并保存到`selectedDate`变量中。`isToday`方法用来判断一个日期是否为今天。`isSelected`方法用来判断一个日期是否为选择状态。 最后,我们需要在Vue组件中使用`v-click-outside`指令来处理日期选择的点击外部区域隐藏弹出框的功能,如下所示: ```javascript directives: { 'click-outside': { bind(el, binding, vnode) { el.clickOutsideEvent = function(event) { if (!(el === event.target || el.contains(event.target))) { vnode.context[binding.expression](event) } } document.body.addEventListener('click', el.clickOutsideEvent) }, unbind(el) { document.body.removeEventListener('click', el.clickOutsideEvent) } } } ``` 在上面的代码中,我们使用了`v-click-outside`指令来处理日期选择的点击外部区域隐藏弹出框的功能。我们定义了一个`click-outside`指令,并在其中使用了`addEventListener`和`removeEventListener`方法来监听和移除点击事件。 以上就是滚动日期选择的Vue实现方法。希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值