首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原生 JS 实现惯性滚动,给鼠标滚轮增加阻尼感,纵享丝滑

然而鼠标滚轮的传感器通常采用光电或机械的方式运作,由一个旋转轴和一个传感器组成,旋转轴通常无法做出细微的距离控制,使得距离检测更像是段落式的,这些信号在传输到计算机后,并不能实现丝滑的滚动。...可以通过以下例子感受两种滚动的差异:图片https://code.juejin.cn/pen/7272919488994279484本文将教会你如何让鼠标滚轮也能够丝滑地操作网页,带来更舒适的页面惯性滚动体验...,同时讲解其中技术原理与细节,用最少量的代码实现 JS 鼠标惯性滚动。...实现原理首先需要利用 DOM 事件禁止鼠标滚动,转为 JS 控制。...通过滚轮事件中的 deltaY、deltaX 值获取到最终滚动距离,浏览器帧绘制函数 requestAnimationFrame 来逐帧设置页面的 scrollTop 达到模拟滚动的效果,并利用线性插值或缓动函数等数学方法来计算变化过程中的值

1.8K41

Fabric.js 居中元素 🎗️

本文总结了 Fabric.js 常用的将元素居中的方法,其中包括: 基于视窗的水平居中 基于画布的水平居中 带动画效果的水平居中 基于视窗的垂直居中 基于画布的垂直居中 带动画效果的垂直居中 同时实现水平和垂直居中...阅读本文需要你有一定的 Fabric.js 基础,如果还不太了解 Fabric.js 是什么,可以阅读 《Fabric.js 从入门到膨胀》 创建基础项目 为了方便演示,我在初始化画布的时: 添加一个背景图...添加鼠标滚轮滚动时缩放画布(方便演示 基于视窗 和 基于画布 的区别)。 添加鼠标拖拽画布平移位置(方便演示 基于视窗 和 基于画布 的区别)。...canvas.add(rect) // 滚轮滚动时可修改画布缩放等级 canvas.on('mouse:wheel', opt => { const delta = opt.e.deltaY...canvas.viewportTransform) // 设置此画布实例的视口转换 canvas.isDragging = false }) 复制代码 代码有点多,但 滚轮滚动时可修改画布缩放等级

3.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Vue 实现图片监听鼠标滑轮滚动实现图片缩小放大功能

    实现思路在js中,onmousewheel是鼠标滑轮滚动事件,可以通过这个事件触发来改变图片的大小,实现图片放大缩小功能。但是我们这里是vue所以使用的是:mousewheel。...,显而易见动动鼠标滚轮就能触发事件,但是用光标拖拽滚动条就不能触发事件。...IE和Opera (Presto)仅支持属性和do不支持水平滚动。这wheelDeltaX属性值指示沿水平轴的属性值。当用户操作设备向右滚动时,该值为负。否则,也就是说,如果向左,则值为正。...有火狐鼠标滚轮兼容问题。onmousewheelonmousewheel事件:会在鼠标滚轮滚动的时候被触发,对鼠标滚轮是否滚动进行判断,但是火狐浏览器不支持这个属性。...在页面有滚动条的时候,滚动条会随着鼠标滚轮滚动而滚动,这是浏览器的默认行为,可用return false来取消浏览器的默认行为。有火狐鼠标滚轮兼容问题。

    3.7K20

    JS事件篇

    ---只读 元素.scrollWidth和scrollHeight获取元素整个滚动区域的宽和高 元素.scrollLeft和scrollTop获取水平和垂直滚动条滚动滚动距离 当满足scrollHeight...判断滚轮上滚还是下滚----火狐不支持,由detail替代 取消滚动条随滚轮移动的默认行为 键盘事件 浏览器对象模型---navigator 通过 属性名 in 对象 可以判断对应的属性在当前对象中是否存在...document.getElementById("d1"); alert(d1.scrollHeight); ---- 元素.scrollLeft和scrollTop获取水平和垂直滚动条滚动滚动距离...替代 d1.onmousewheel=function() { alert("鼠标滚轮滚动了"); }; //为div绑定一个鼠标滚轮事件...addEventListener("DOMMouseScroll",function(){ alert("鼠标滚轮"); },false) ---- 判断滚轮上滚还是下滚----火狐不支持,由

    12.6K10

    有意思的水平横向溢出滚动

    来看看这么一种情况: 我们有一个垂直方向溢出滚动的容器,以及一个水平方向溢出滚动的容器: 如果使用的是非触控板(大部分用户没有触控板),而是使用鼠标来进行操作,会发现,这两个容器中,只有垂直方向溢出滚动的容器...,是可以响应鼠标滚轮的: 垂直方向溢出滚动的容器,正常响应鼠标滚轮,可滚动内容 水平方向溢出滚动的容器,不会响应鼠标滚轮,不可滚动内容 那么,这里可能就是一个用户痛点。...如果在一些特定场景下,确实有横向滚动的内容,譬如横向的图片内容展示等。又想使用鼠标滚轮对内容进行滚动,能否做到呢?...那是必须的,本文就将介绍一种可能可行的技巧,在特定场景下在水平方向溢出滚动的容器,依然可以用鼠标滚轮进行滚动。 旋转大法 是的,既然只有垂直方向的溢出,才能响应滚轮操作。那我们不妨从这个角度入手。...,图中鼠标没有在滚动条上容器的运动就是通过滚轮实现的。

    2.5K10

    接上一篇事件详解

    理解客户区坐标位置 含义是:鼠标指针在可视区中的水平clientX和垂直clientY坐标; 理解页面坐标位置pageX和pageY: pageX与pageY是指页面坐标的位置,与clientX和clientY...也都实现了这个事件,当用户通过鼠标滚轮与页面交互,在垂直方向上滚动页面时(无论向上还是向下),就会触发mousewheel事件,这个事件可以在任何元素上触发,最终会冒泡到document(IE8)或window...(IE9,Opera,Chrome,Safari)对象,与mousewheel事件对应的event对象外,还有一个属性wheelDelta属性,当用户向前滚动鼠标滚轮时,wheelDelta是120的倍数...,当用户向后滚动鼠标滚轮时,wheelDelta是-120的倍数。...,与mousewheel事件一样,但是他的有关鼠标滚轮信息保存在detail属性中,当鼠标向前滚动时,这个属性值是-3的倍数,当鼠标滚轮向后滚动时,这个属性值是3的倍数;也可以给DOMMouseScroll

    1.9K60

    图形编辑器基于Paper.js教程09:鼠标拖动画布,以鼠标点为缩放中心进行视图的缩放

    如何使用Paper.js实现画布的缩放与拖动功能 在Web开发中,利用Paper.js库进行图形的绘制和交互操作是一种常见的实践。...(作者:CSDN@拿我格子衫来) 效果图 环境设置与基本图形绘制 首先,我们需要在HTML中引入Paper.js,并设置一个画布: 鼠标滚轮事件来实现的。...当用户滚动鼠标滚轮时,我们根据滚动方向调整画布的缩放比例: paper.view.element.addEventListener('wheel', function (event) { event.preventDefault...在onMouseDrag事件中,我们计算从上一次事件到当前事件鼠标移动的差值,并相应地调整视图中心,实现拖动效果。最后,在onMouseUp事件中结束拖动。

    14710

    《最新出炉》系列入门篇-Python+Playwright自动化测试-45-鼠标操作-下篇

    (滚轮事件如果不处理可能会导致滚动,该方法不会等待滚动结束才返回。)...4.1参数详解 参数 类型 释义 delta_x float 要水平滚动的像素 delta_y float 要垂直滚动的像素 4.2使用方法 mouse.wheel(delta_x...如下图所示: 6.wheel模拟鼠标滚动 wheel模拟鼠标滚动,就是通过调度一个wheel事件。(滚轮事件如果不处理可能会导致滚动,该方法不会等待滚动结束才返回。)...6.1参数详解 参数 类型 释义 delta_x float 要水平滚动的像素 delta_y float 要垂直滚动的像素 6.2使用方法 mouse.wheel(delta_x...我正在参与2024腾讯技术创作特训营最新征文,快来和我瓜分大奖!

    24520

    学习滚动插件iScroll的简单使用

    它不支持快速跳跃,滚动条,鼠标滚轮,快捷键绑定。但如果你所需要的是滚动(特别是在移动平台) iScroll 精简版 是又小又快的解决方案(这个能应付大多数场景)。...iscroll-probe.js,探查当前滚动位置是一个要求很高的任务,这就是为什么我决定建立一个专门的版本。如果你需要知道滚动位置在任何给定的时间,这是iScroll给你的。...(我正在做更多的测试,这可能最终在常规iscroll.js脚本,请留意)。 iscroll-zoom.js,在标准滚动功能上增加缩放功能。...('#wrapper'); 配置参数说明 var myScroll = new IScroll('#wrapper', { mouseWheel: true, //是否监听鼠标滚轮事件...scrollCancel初始化滚动后又取消scrollStart开始滚动scroll滚动中scrollEnd滚动结束flick轻击屏幕左、右zoomStart开始缩放zoomEnd缩放结束 iScroll

    2.9K30

    《最新出炉》系列入门篇-Python+Playwright自动化测试-46-鼠标滚轮操作

    1.简介有些网站为了节省流量和资源,提高加载效率,采用的是动态加载(懒加载)的,也就是当拖动页面右侧滚动条后会自动加载网页下面的内容,不拖动就不会加载的或者通过鼠标滚轮操作。...2.wheel模拟鼠标滚动wheel模拟鼠标滚动,就是通过调度一个wheel事件。(滚轮事件如果不处理可能会导致滚动,该方法不会等待滚动结束才返回。)...: float Pixels to scroll vertically. """2.1参数详解参数 类型 释义 delta_xfloat要水平滚动的像素...Created on 2023-12-16@author: 北京-宏哥公众号:北京宏哥Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-45-鼠标滚轮操作'''#...我正在参与2024腾讯技术创作特训营最新征文,快来和我瓜分大奖!

    38820

    随心所欲的滚动条,远离产品汪(二)

    滚轮事件及兼容问题概要 在鼠标上,除了点击、拖拽等事件,当然也少不了滚轮事件了,但是比较有意思的一点是,平常大家碰到兼容问题首先想到了IE这个万年背锅侠,但是这次还真不是,火狐别树一帜的凑了一回热闹。...1.在滚轮事件中,火狐的的滚动事件是DOMMouseScroll,而其它浏览器是mousewheel,这一点是要仔细留意的。 2.在事件对象的兼容中。...首先,我们需要明白我们的滚轮是作用在谁的身上,根据实际需求来进行事件绑定,当我们鼠标移入可视区时,会触发滚轮事件,在移出可视区时则清除滚轮事件,接下来进行具体代码操作。...较之上篇的实现代码,本篇中增加了两个变量。 1.通过设置变量Judge来判断滚轮的滚动方向,当Judge为ture时,滚轮向上滚动,当Judge为false时,滚轮向下滚动。...// 拖动的最大极限值 nowDisY = 0, // 点击滚动条C时距父级顶部的高度 judge = 0, // 判断鼠标滚轮的方向

    2K80

    jquery nicescroll 配置参数

    div,默认值是9999 scrollspeed - 滚动速度,默认值为60 mousescrollstep - 高速滚动鼠标滚轮,默认值是40(像素) touchbehavior - 使光标拖动滚动像在台式电脑触摸设备...(默认:false) hwacceleration - 使用硬件加速滚动支持的时候(默认:true) boxzoom - 使变焦框中的内容(默认:false) dblclickzoom - (仅当boxzoom...,冒泡鼠标滚轮事件(默认:true) railoffset,您可以添加抵消顶部/左边的轨道位置(默认:false) bouncescroll,使滚动弹跳在内容结尾作为移动像(仅HW ACCELL)(...,对于chrome浏览器,停用大纲(橙色hightlight)选择具有nicescroll一个div(默认: true)时, horizrailenabled,nicescroll可以管理水平滚动(...CSS转换为滚动内容(默认:true) enablemousewheel,nicescroll可以管理的鼠标滚轮事件(默认:true) enablekeyboard,nicescroll可以管理键盘事件

    4.1K80

    面试官:哪些浏览器事件不会冒泡?

    回答这个问题之前,我们首先要具备DOM事件流捕获与冒泡的知识,这里只讲JS中如何设置这两种事件监听,例如对body注册点击事件:document.body.addEventListener('click...在JS中通常利用冒泡来进行事件委托,但并不是所有事件都会冒泡。下面我们看看哪些事件是不能冒泡的,又有哪些相关应用场景。...注意:有个类似滚动事件的叫滚轮事件wheel是可以触发冒泡的( MDN - wheel_event ),我们甚至可以通过额外注册 wheel 监听事件并阻止其冒泡从而让 scroll 事件失效,不过只要滚动条还在...scroll 还是可以不通过滚轮来控制滚动的,所以还记得前面我们怎么让元素滚动起来的吗?...就是设置了 overflow: scroll;,所以控制滚动应该使用 CSS 而不是 JS 事件。

    1.8K20

    关于ScrollViewr和滚动轮劫持(scroll-wheel-hijack)

    所谓的滚动轮劫持,简单来说即是在一个可以滚动的页面使用鼠标滚轮滚动页面的过程中鼠标进入某个可以滚动的子元素导致只在这个子元素中滚动而整个页面想滚滚不动了。 具体看看这个例子: ?...当然还有另外很多种情况的滚动轮劫持,也有很多解决方案,这篇文章只介绍我遇到的情况和我的解决方案。 2....这里面用到几个属性: MouseWheelEventArgs中的Delta表示鼠标滚轮的变更量,当这个值为正数时表示滚轮向上。 ExtentHeight,获取ScrollViewer内容的实际高度。...熟悉了上面几个属性的作用后我们可以更好地控制鼠标滚轮的行为,当鼠标向上滚动时,判断现在是否已经滚到顶了,如果是就不处理鼠标滚轮事件: if (VerticalOffset == 0 && e.Delta...>= 0) return; 而当鼠标向下滚动时,需要根据ViewportHeight、VerticalOffset和ExtentHeight判断当前是否已经滚动到底,如果是就不处理鼠标滚轮事件

    1.4K30

    jimojianghu

    触控板 要禁止触控板的缩放行为,需要处理鼠标滚轮事件:wheel 。 因为笔记本触摸板双指滑动,将响应该事件,如果对该事件阻止默认行为,就能解决缩放问题了。...此外,对 document 处理了滚轮事件后,因为该事件会传播冒泡,所以需要注意页面上其他的子元素——如果有滚动条之类的,需要在子元素上阻止冒泡,不然后滚动会失效。...笔记本触摸板双指滑动,将响应滚轮事件,因此可以监听该事件,禁止触摸板手指缩放界面。 但需要注意滚轮默认事件,如会导致子元素滚动失效,这时候就要在子元素上阻止相同事件冒泡。...特别是浏览器优化页面滚动时的性能,可以让页面滚动更顺滑。 在Chrome中,wheel / touch 等事件中的 passive 会默认设置为true,但Safari不支持。...添加 passive 参数为true后,touchmove 事件不会阻塞页面的滚动(同样适用于鼠标的滚轮事件)。

    3.8K00
    领券