slider-100.uvue 1.1 KB
Newer Older
H
hdx 已提交
1
<template>
H
hdx 已提交
2 3
  <scroll-view class="page">
    <page-head :title="title"></page-head>
H
hdx 已提交
4 5 6
    <view class="grid-view">
      <slider ref="slider" class="slider" v-for="(_, index) in 100" :key="index" @changing="sliderChanging"
        @change="sliderChange" :value="sliderValue" :block-size="20" :show-value="true" />
H
hdx 已提交
7
    </view>
DCloud-WZF's avatar
DCloud-WZF 已提交
8
  </scroll-view>
H
hdx 已提交
9 10
</template>

H
hdx 已提交
11 12 13 14 15
<script>
  export default {
    data() {
      return {
        title: 'slider 滑块 x 100',
H
hdx 已提交
16
        sliderValue: 50
H
hdx 已提交
17
      }
DCloud-WZF's avatar
DCloud-WZF 已提交
18
    },
H
hdx 已提交
19
    methods: {
H
hdx 已提交
20
      sliderChange(e : UniSliderChangeEvent) {
H
hdx 已提交
21 22
        this.updateSliderValue(e.detail.value)
      },
H
hdx 已提交
23
      sliderChanging(e : UniSliderChangeEvent) {
H
hdx 已提交
24 25
        this.updateSliderValue(e.detail.value)
      },
H
hdx 已提交
26
      updateSliderValue(value : number) {
H
hdx 已提交
27
        // TODO 跳过vue框架,直接修改原生组件
H
hdx 已提交
28
        (this.$refs["slider"] as UniSliderElement[]).forEach((item) => {
H
hdx 已提交
29 30
          item.value = value
        });
H
hdx 已提交
31
      }
H
hdx 已提交
32 33
    },
  }
H
hdx 已提交
34 35 36
</script>

<style>
H
hdx 已提交
37 38 39 40
  .page {
    flex: 1;
  }

H
hdx 已提交
41
  .grid-view {
H
hdx 已提交
42
    flex-direction: row;
H
hdx 已提交
43
    flex-wrap: wrap;
H
hdx 已提交
44
  }
H
hdx 已提交
45

H
hdx 已提交
46
  .slider {
H
hdx 已提交
47 48 49
    width: 25%;
    margin-top: 1px;
    margin-bottom: 1px;
H
hdx 已提交
50
  }
51
</style>