中国互联网协会官方网站,做网站需要哪个系统,做塑胶原料用什么网站好,网页设计图片代码个人项目地址#xff1a; SubTopH前端开发个人站 #xff08;自己开发的前端功能和UI组件#xff0c;一些有趣的小功能#xff0c;感兴趣的伙伴可以访问#xff0c;欢迎提出更好的想法#xff0c;私信沟通#xff0c;网站属于静态页面#xff09; SubTopH前端开发个人站…个人项目地址 SubTopH前端开发个人站 自己开发的前端功能和UI组件一些有趣的小功能感兴趣的伙伴可以访问欢迎提出更好的想法私信沟通网站属于静态页面 SubTopH前端开发个人站https://subtop.gitee.io/subtoph.github.io/#/home
以上 是个人前端项目欢迎提出您的建议
以下是正文内容...............
实现效果 直接上代码
组件文件
templatediv classswh-range-page :idonlyId refrangeRefdiv classswh-range-selection :idonlyId _selection!-- 滑动槽 --div classswh-trough clickhandleTroughClick/div!-- 选中范围高亮条 --pclassswh-drag-trough:idonlyId _drag-troughclickhandleTroughClick/p!-- 拖拽按钮 --p classswh-drag-btn :idonlyId _drag-btn/pp classdrag-value :idonlyId _drag-value{{ rangValue }}/p/div/div
/templatescript
import { reactive, toRefs, onBeforeMount, onMounted, ref, nextTick } from vue;
import { findCloseNum, handleStepNumber } from /utils/common.js;
export default {name: ,props: {minValue: {type: Number,default: 0,explain: 范围最小值,otherVal: ---},maxValue: {type: Number,default: 100,explain: 范围最大值,},// 初始值initValue: {type: Number,default: 0,explain: 设置初始值,},// 是否设置初始值setInitValue: {type: Boolean,default: true,explain: 是否使用初始值(true时initValue有效),},getRangChange: {type: Function,explain: 数值发生变化}},setup(props, ctx) {const data reactive({dragEle: null, //推拽槽元素rangeEle: null, //推拽按钮元素dragTrough: null, //推拽的条元素clickPos: 0, //点击移动按钮时鼠标距离父级的位置moveLeft: 0, //移动的leftrangeWidth: 0, //范围盒子宽度btnWidth: 0, //拖拽按钮尺寸rangValue: 0, //选中值optionalRange: 0, //实际范围rangArr: [], //范围段数组onlyId: });const rangeRef ref(null); // 获取当前组件中外层元素onBeforeMount(() {});onMounted(() {nextTick(() {// 获取组件数量const ele document.getElementsByClassName(swh-range-page);if (ele.length) {for (let i 0; i ele.length; i) {// 组件和当前ref获取的组件本身相等就设置idif (rangeRef.value ele[i]) {data.onlyId swhRangeRef_${i}; //设置显示框id}}}nextTick(() {init();});});});const init () {const { onlyId } data;data.rangeCom document.querySelector(#${onlyId});data.dragEle document.querySelector(#${onlyId}_drag-btn);data.dragValueEle document.querySelector(#${onlyId}_drag-value);data.rangeEle document.querySelector(#${onlyId}_selection);data.dragTrough document.querySelector(#${onlyId}_drag-trough);data.btnWidth data.dragEle.offsetWidth;data.rangeWidth data.rangeEle.offsetWidth;data.dragEle.style.left -data.btnWidth / 2 px;// 设置默认值,没有就是最小值const { setInitValue, initValue, minValue, maxValue } props;if (setInitValue) {// 设置默认值if (initValue minValue initValue maxValue) {// 初始值在范围内data.rangValue initValue;} else {console.error(未设置初始值或者初始值超出范围);data.rangValue minValue;}} else {// 未设置默认值,默认最小值data.rangValue props.minValue;}// 最大值减区最小值是 实际范围data.optionalRange props.maxValue - props.minValue;// 获取分割范围数组data.rangArr handleStepNumber(data.rangeWidth, data.optionalRange);initMovePosition();bindEvent();};// 初始化值所在的位置const initMovePosition () {const index rangNumArr().indexOf(data.rangValue);if (index ! -1) {const proportion index / data.optionalRange;const initLeft data.rangeWidth * proportion;data.moveLeft initLeft;moveLeft();}};// 范围数值数组const rangNumArr () {let rNumArr [];for (let i 0; i data.optionalRange 1; i) {rNumArr.push(props.minValue i);}return rNumArr;};// 事件监听const bindEvent () {data.dragEle.addEventListener(mousedown, handleMouseDown, false);};// 按下事件const handleMouseDown (e) {// 点击时鼠标距离父级left 减去已经实际移动的距离data.clickPos e.clientX - data.rangeEle.offsetLeft - data.moveLeft;document.addEventListener(mousemove, handleMouseMove, false);document.addEventListener(mouseup, handleMouseUp, false);};// 移动处理const handleMouseMove (e) {// 获取实际移动的位置,移动后left减去点击时clickPos(left)是实际移动的leftconst inMoveleft e.clientX - data.rangeEle.offsetLeft;// 移动的距离 - 开始点击的位置 实际移动距离data.moveLeft inMoveleft - data.clickPos;moveLeft();};// 直接点击范围条,改变拖拽按钮选中位置const handleTroughClick (e) {// 鼠标点击位置减去元素距离body的left,获取点击在跳上的left距离const inMoveleft e.clientX - data.rangeCom.getBoundingClientRect().left;// 距离减去按钮宽度未实际移动leftdata.moveLeft inMoveleft - data.btnWidth;moveLeft();};// 移动位置const moveLeft () {// 调整实际移动的距离if (data.moveLeft data.rangeWidth) {// 最大限制data.moveLeft data.rangeWidth;} else if (data.moveLeft 0) {// 最小限制data.moveLeft 0;} else {// 移动至鼠标最接近的范围点上data.moveLeft findCloseNum(data.rangArr, data.moveLeft);}//按键 移动的距离减去按键一半宽度data.dragEle.style.left data.moveLeft - data.btnWidth / 2 px;//设置选中范围条宽度data.dragTrough.style.width data.moveLeft px;// 移动的占比const proportion data.moveLeft / data.rangeWidth;// 计算移动的值data.rangValue parseInt(data.optionalRange * proportion) props.minValue;// 计算提示数值的偏移位置const wc (data.dragValueEle.offsetWidth - data.btnWidth) / 2;// 设置显示范围值的提示位置,设置按钮的位置即可data.dragValueEle.style.left data.dragEle.offsetLeft - Math.abs(wc) px;ctx.emit(getRangChange, data.rangValue);};// 移除事件监听const handleMouseUp () {document.removeEventListener(mousemove, handleMouseMove, false);document.removeEventListener(mouseup, handleMouseUp, false);};return {rangeRef,handleTroughClick,...toRefs(data)};}
};
/script
style scoped langless
.swh-range-page {position: relative;min-width: 160px;width: 100%;display: flex;padding: 0 20px;justify-content: center;border-radius: 10px;.swh-range-selection {position: relative;width: 100%;height: 30px;z-index: 9;.swh-trough {position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);width: 100%;height: 5px;background: rgb(243, 243, 243);border-radius: 3px;cursor: pointer;}.swh-drag-btn {position: absolute;top: 50%;left: 0;width: 20px;height: 20px;background: #fff;border: 2px solid TSB;transform: translateY(-50%);border-radius: 50%;z-index: 1;cursor: pointer;box-sizing: border-box;:hover {transform: translateY(-50%) scale(1.1);transition: 0.3s;}}.swh-drag-trough {cursor: pointer;position: absolute;top: 50%;left: 0;transform: translateY(-50%);background: TSB;height: 5px;border-radius: 3px;}.drag-value {position: absolute;top: -20px;left: 0px;border-radius: 5px;width: 30px;height: 20px;background: rgba(0, 0, 0, 0.8);font-size: 12px;line-height: 20px;color: #fff;text-align: center;}}
}
/style组件使用到的findCloseNum方法
// 判断当前数字 最靠近数组中那个数字
export function findCloseNum(arr, num) {var index 0; // 保存最接近数值在数组中的索引var old_value Number.MAX_VALUE; // 保存差值绝对值默认为最大数值for (var i 0; i arr.length; i) {var new_value Math.abs(arr[i] - num); // 新差值if (new_value old_value) { // 如果新差值绝对值小于等于旧差值绝对值保存新差值绝对值和索引if (new_value old_value arr[i] arr[index]) { // 如果数组中两个数值跟目标数值差值一样取大continue;}index i;old_value new_value;}}return arr[index] // 返回最接近的数值
} 组件使用到的handleStepNumber方法
export function handleStepNumber(w, r) {const itemPx w / r;let rangArr [];for (let i 0; i r1; i) {rangArr.push(Math.ceil(itemPx * i));}return rangArr;
};
1.组件可以实现最小值和最大值的设置
2.可初始化值
3.组件长度根据父组件自定义
4.滑动和点击会改变范围值
根据自己的需求可进行更多扩展