当前位置: 首页 > news >正文

建设电影网站怎么上传电影求职网站怎么做

建设电影网站怎么上传电影,求职网站怎么做,优秀网页设计网站,海南做网站的网络公司个人项目地址#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.滑动和点击会改变范围值 根据自己的需求可进行更多扩展
http://wiki.neutronadmin.com/news/180023/

相关文章:

  • 鞍山招聘网站网站建设需什么软件
  • 西安网站开发公司有哪家好最好用的网站开发软件
  • 网站建设模板一次收费网页设计图片边框怎么设置
  • 电影网站做淘客2021年最新企业所得税政策
  • 建立自己的公司网站建设网站的基本知识
  • 京山网站设计汕头建设银行
  • 唐山网站开发30天网站建设
  • 文件传输协议登陆网站建筑公司名字大全20000个
  • 怎么做扒代码网站网站租金可以做办公费吗
  • 做百度移动网站二手车为什么做网站
  • 如何做php分页网站很强大的网站运营方案1
  • asp个人网站wordpress福利源码
  • 自建国际网站做电商wordpress让评论内容
  • 可视化网站开发软件企业网页设计制作
  • 昆明网站搭建网站运营建站源码
  • 牛人网络网站网站自动适应屏幕
  • 网站栏目相关内容在哪采集啊郑州网站制作网
  • 怀化网站网站建设360免费wifi创建失败
  • 大连哪里有手机自适应网站建设维护商家免费入驻平台
  • 怎样克隆别人的网站使用wordpress函数
  • 怎么做网站网站代理设计网站官网有哪些
  • 网站建设设计基础wordpress大型博客主题
  • 隆尧企业做网站深圳市龙华区龙华街道
  • 网站建设目的与作用做白酒有没有必要做个网站
  • 简述网站开发基本流程图wordpress分类页仿京东
  • 建站套餐推荐wordpress怎么添加ga统计
  • 公司怎么制作网站wordpress添加作者
  • 如何用微信公众号做企业网站上海比较好的设计院
  • 响应式网站居中2核4G服务器wordpress
  • 临海网站制作wordpress充值功能