slider - 支持step,增加step计算逻辑
This commit is contained in:
		
							parent
							
								
									adaf72fc21
								
							
						
					
					
						commit
						f616820bd9
					
				@ -7,7 +7,7 @@
 | 
			
		||||
::: demo
 | 
			
		||||
 | 
			
		||||
<template>
 | 
			
		||||
  <lay-slider v-model="value1" :disabled="false"></lay-slider>
 | 
			
		||||
  <lay-slider :step="5" v-model="value1" :disabled="false"></lay-slider>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
 | 
			
		||||
@ -123,14 +123,10 @@ const props = withDefaults(defineProps<LaySliderProps>(), {
 | 
			
		||||
  vertical: false,
 | 
			
		||||
  modelValue: 0,
 | 
			
		||||
  disabled: false,
 | 
			
		||||
  step: 1,
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
// let rangeValue: Ref<number[]> = ref([0, 0]);
 | 
			
		||||
let rangeValue: Ref<number[]> | any = toRef(props, "standardrange");
 | 
			
		||||
// if (Array.isArray(props.modelValue)) {
 | 
			
		||||
//   // eslint-disable-next-line vue/no-setup-props-destructure
 | 
			
		||||
//   rangeValue.value = props.modelValue;
 | 
			
		||||
// }
 | 
			
		||||
 | 
			
		||||
let verticalRangeValue: Ref<number[]> | any = toRef(props, "verticalrange");
 | 
			
		||||
 | 
			
		||||
@ -139,10 +135,10 @@ const verticaltracker = ref<HTMLElement | null>(null);
 | 
			
		||||
const rangetracker1 = ref<HTMLElement | null>(null);
 | 
			
		||||
const rangetracker2 = ref<HTMLElement | null>(null);
 | 
			
		||||
 | 
			
		||||
const standard_style = reactive({
 | 
			
		||||
  left: props.modelValue,
 | 
			
		||||
  width: props.modelValue,
 | 
			
		||||
});
 | 
			
		||||
// const standard_style = reactive({
 | 
			
		||||
//   left: props.modelValue,
 | 
			
		||||
//   width: props.modelValue,
 | 
			
		||||
// });
 | 
			
		||||
 | 
			
		||||
const vertical_style = reactive({
 | 
			
		||||
  bottom: props.modelValue,
 | 
			
		||||
@ -156,7 +152,7 @@ function throttle(func: Function) {
 | 
			
		||||
      timer = setTimeout(() => {
 | 
			
		||||
        timer = null;
 | 
			
		||||
        func(args);
 | 
			
		||||
      }, 60);
 | 
			
		||||
      }, 50);
 | 
			
		||||
    }
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
@ -199,6 +195,7 @@ function handle_mouseup() {
 | 
			
		||||
function handle_select(e: Event): void {
 | 
			
		||||
  e.preventDefault();
 | 
			
		||||
}
 | 
			
		||||
let standard_style: Ref<number> = ref<number>(props.modelValue as number);
 | 
			
		||||
 | 
			
		||||
const standardMove = (e: MouseEvent) => {
 | 
			
		||||
  if (!standardtracker.value) {
 | 
			
		||||
@ -209,18 +206,16 @@ const standardMove = (e: MouseEvent) => {
 | 
			
		||||
  let point_left = e.clientX;
 | 
			
		||||
  let distance = point_left - origin_left;
 | 
			
		||||
  if (distance < 0) {
 | 
			
		||||
    standard_style.left = 0;
 | 
			
		||||
    standard_style.width = 0;
 | 
			
		||||
    standard_style.value = 0;
 | 
			
		||||
    // standard_style.width = 0;
 | 
			
		||||
  } else {
 | 
			
		||||
    let rate = (distance / tracker_rect.width) * 100;
 | 
			
		||||
    standard_style.left = Math.floor(rate);
 | 
			
		||||
    standard_style.width = Math.floor(rate);
 | 
			
		||||
    if (standard_style.left > 100) {
 | 
			
		||||
      standard_style.left = 100;
 | 
			
		||||
      standard_style.width = 100;
 | 
			
		||||
    calcWithStep(rate, standard_style);
 | 
			
		||||
    if (standard_style.value > 100) {
 | 
			
		||||
      standard_style.value = 100;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  emit("update:modelValue", standard_style.left);
 | 
			
		||||
  emit("update:modelValue", standard_style.value);
 | 
			
		||||
};
 | 
			
		||||
const verticalMove = (e: MouseEvent) => {
 | 
			
		||||
  if (!verticaltracker.value) {
 | 
			
		||||
@ -302,4 +297,18 @@ function moveNeighbors(rate: number, rangeValues: any) {
 | 
			
		||||
    return 0;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function calcWithStep(rate: number | undefined, val: Ref<number>) {
 | 
			
		||||
  if (typeof rate === "undefined") return false;
 | 
			
		||||
  let r = rate - val.value;
 | 
			
		||||
  if (Math.abs(r) < props.step) {
 | 
			
		||||
    return false;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (r < 0) {
 | 
			
		||||
    val.value -= props.step;
 | 
			
		||||
  } else {
 | 
			
		||||
    val.value += props.step;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user