<el-slider change 带参数
时间: 2023-08-26 22:09:13 浏览: 218
回答: 根据引用[1]中的代码,el-slider组件的change事件是带有参数的。在change事件的回调函数中,参数val表示滑动条的当前值。可以通过Math.floor(val)来将val的值取整。然后可以根据需要对取整后的值进行处理,比如将其赋值给number属性。所以,<el-slider>的change事件带有参数,并且可以在回调函数中对参数进行处理。
相关问题
使用vue2修改下述代码,让el-slider滑块控制el-date-picker的时间,滑块的初始最大最小值为el-date-picker的初始值,随着滑块滑动el-date-picker的值会改变 <div> <el-date-picker v-model="value1" type="datetimerange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker> <el-slider range style="padding:0 12px;" @change="onChange"></el-slider> </div>
可以使用Vue的计算属性和watch来实现这个功能。具体实现如下:
```
<template>
<div>
<el-date-picker
v-model="dateRange"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
></el-date-picker>
<el-slider
range
style="padding:0 12px;"
:min="minTime"
:max="maxTime"
v-model="sliderValue"
></el-slider>
</div>
</template>
<script>
export default {
data() {
return {
dateRange: [], // 日期范围
sliderValue: [], // 滑块的值
};
},
computed: {
minTime() {
// 计算最小时间
return this.dateRange[0] ? this.dateRange[0].getTime() : 0;
},
maxTime() {
// 计算最大时间
return this.dateRange[1] ? this.dateRange[1].getTime() : new Date().getTime();
},
},
watch: {
sliderValue(val) {
// 监听滑块的值变化,修改日期范围
this.dateRange = [new Date(val[0]), new Date(val[1])];
},
dateRange(val) {
// 监听日期范围变化,修改滑块的值
this.sliderValue = [val[0].getTime(), val[1].getTime()];
},
},
};
</script>
```
在这个代码中,我们首先使用了一个计算属性来计算滑块的最小值和最大值。然后使用了一个watch来监听滑块和日期范围的变化,并根据变化来修改另一个的值。最终实现了滑块控制日期范围的功能。
使用vue2修改下述代码,el-date-picker初始值分别为今天0点和明天0点。让el-slider滑块控制el-date-picker的时间,滑块的初始最大最小值为el-date-picker的初始值的getTime(),滑块滑动时与el-date-picker联动。 <div> <el-date-picker v-model="value1" type="datetimerange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker> <el-slider range style="padding:0 12px;" @change="onChange"></el-slider> </div>
<>
<div>
<el-date-picker
v-model="value1"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-value="defaultValue"
:picker-options="pickerOptions"
></el-date-picker>
<el-slider
range
style="padding: 0 12px;"
:min="min"
:max="max"
v-model="sliderValue"
@change="onSliderChange"
></el-slider>
</div>
</template>
<script>
export default {
data() {
return {
value1: [new Date(), new Date(Date.now() + 86400000)],
sliderValue: [new Date().getTime(), new Date(Date.now() + 86400000).getTime()],
pickerOptions: {
selectableRange: '00:00:00 - 23:59:59'
}
}
},
computed: {
min() {
return this.value1[0].getTime()
},
max() {
return this.value1[1].getTime()
},
defaultValue() {
return [new Date(new Date().toLocaleDateString()), new Date(new Date().toLocaleDateString() + ' 23:59:59')]
}
},
methods: {
onSliderChange() {
const [start, end] = this.sliderValue
this.value1 = [new Date(start), new Date(end)]
}
}
}
</script>
阅读全文