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

如何在angular 5中点击滚动条触发事件

在Angular 5中,可以通过使用HostListener装饰器来监听滚动条的点击事件。下面是一个示例代码:

代码语言:txt
复制
import { Component, HostListener } from '@angular/core';

@Component({
  selector: 'app-scroll',
  template: `
    <div class="scroll-container" (click)="onScrollClick()">
      <!-- 滚动内容 -->
    </div>
  `,
  styles: [`
    .scroll-container {
      height: 200px;
      overflow-y: scroll;
    }
  `]
})
export class ScrollComponent {
  @HostListener('click', ['$event.target'])
  onScrollClick(target: HTMLElement) {
    // 在这里处理滚动条点击事件
    console.log('滚动条被点击了');
  }
}

在上面的代码中,我们使用了HostListener装饰器来监听click事件,并通过$event.target参数获取到被点击的元素。然后在onScrollClick方法中可以处理滚动条点击事件。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

记录工作中遇到的各种问题(Bug,总结,记录)

第一次成功打印出来,即触发了load事件,但点击下一页后,iframe实际上已经刷新了,但并不会再触发这个load事件 后来的解决办法是换了种监听方法,区别主要是获取iframe对象的方式变了,还不知为啥会这样...中性能面板汇总可以看到,在键盘按下和松开的时候,会触发Angular的keypress和keyup事件,每个耗时几百毫秒 解决办法就是对不需要绑定的数据,尽量不用Angular自建的绑定,换成普通方式就好...(JQ的绑定) 目前在Angular中还比较滥用JQ,以后得多注意 关于Angular的性能优化也有很多需要去慢慢了解,比如 speeding-up-angular-js-with-simple-optimizations...后来发现是点击中间时可以,但点击边缘就没反应 ? 看了源码发现,文件input[file]项是通过点击label模拟触发的 而label的可点击区域实际上是上图中的元素 ? ? ?...Mac的Safari中触发input[type="file"]点击失效 safari下会有很多安全性的问题,关于文件选择项的触发,原生的文件选择框的样式不太好修改,一般会隐藏掉然后用一个输入框代替,点击后再触发文件的选择

18.1K12

小程序开发基础-scroll-view 可滚动视图区域

scrolltolower事件,bindscrolltolower="lower"表示绑定事件lower,会触发scrolltolower事件。...,下一个视图,如同翻页的效果,点击按钮切换到下一个view,另一个按钮的点击效果为,设置滚动条位置实现画面滚动,就是下移或上移等。...scrolltoupper事件 lower-threshold 表示距底部或者右边多远时时(单位为px),触发scrolltolower事件 scroll-top 表示设置竖向滚动条位置 scroll-left...表示滚动时触发 enable-back-to-top 表示iOS点击顶部状态栏、安卓双击标题栏时,滚动条返回顶部,只支持竖向 class="scroll-view-item bc_green"中,在...,lower为滚动条滚到底部的时候触发,scroll为滚动条滚动后触发,tap为点击按钮切换到下一个view,tapMove为通过设置滚动条位置实现画面滚动。

2.5K40
  • AngularJS的digest循环和$apply

    一、传统事件触发 在标准的浏览器流程中,页面加载、$http请求返回响应、鼠标移动以及按钮被点击等情况都会触发事件。...当事件触发时(比如点击一个链接),JavaScript会创建一个事件对象,并执行这个事件对象所在的监听特定事件的所有函数。然后浏览器会执行注册给该事件的回调函数,更新DOM。...当使用angular时,其会扩展这个标准的浏览器流程,创建一个angular上下文(angular事件循环内的特定代码,该angular事件循环通常被称为$digest循环)。...循环之前,会触发该值(ng-model)上运行的验证和格式化操作; (5)由于在digest循环中值发生了变化,angular需要再次运行这一循环以确定它没有改变作用域对象上的其他值。...四、$apply从外部进入上下文 所有指令ng-[event]指令(ng-click)都会调用scope.scope.apply(),以强制运行$digest循环。

    3.2K41

    uni-app中使用scroll-view滚到底部时多次触发scrolltolower

    false iOS点击顶部状态栏、安卓双击标题栏时,滚动条返回顶部,只支持竖向 微信小程序 show-scrollbar Boolean false 控制是否出现滚动条 App-nvue 2.1.5+...但是使用scroll-view导致页面级没有滚动,则触底事件不会被触发,所以这里存在的问题是有时候无法触发onReachBottom。   ...最终选择了适用scroll-view自带的滚到底部触发事件scrolltolower事件,虽然这个事件确实能够实现上拉加载数据分页的功能,但是这个是事件存在两个问题。...第一个问题就是当滚动条滚动到底部时会多次触发scrolltolower事件,第二个问题是当页面由第一个scroll-view(该页面已经到了的最底部了)切换到第二个scroll-view时会自动滚动到页面的最底部...,首先默认为0,当页面向下滚动会触发scroll-top事件从而改变scrollTop的值,当切换到第二个scroll-view时在默认设置scrollTop为0,那么在切换到第二个页面的同时页面的竖向滚动条的位置会默认滚动到最顶部

    8.5K10

    导航栏滚动吸顶并自动高亮和点击跳转锚点

    那么需要我们自己手动来实现以下,具体实现思路就是增加滚动条监听事件,当滚动到导航栏指定内容区域时,给其导航栏增加高亮样式,点击导航栏时,计算好滚动条的滚动距离,让其滚动过去即可。...我这次采用的是react来写,具体思路都是相同的,无论你用的是vue还是angular 还是使用jq还是原生js,都是一样的。...这样我们就实现了通过滚动条来控制导航栏高亮的效果了,接下了我们要实现的便是点击导航栏自动定位到其所在内容。...首先要做的一件事就是给导航栏增加一个点击事件 <a className={activeNav==item.id?"...,并超过导航栏位置自动吸顶效果,同时点击导航栏滚动条缓动至锚点位置,实现的最终效果可以看阿里云市场详情页中的效果,比他显示的效果多了滚动条缓动效果。

    10.5K50

    实战 | Change Detection And Batch Update

    我们别急着下结论,我们知道应用程序状态的改变主要是下面三种情况引起的: Events - 点击按钮 Timers - setTimeout XHR - 从服务器获取数据 我们才测试了事件这一种情景,...如果我们不使用Angular1提供的事件系统、定时器和$http,如在jQuery事件中进行数据更新时,我们需要手动调用$apply。...Angular2更新机制大体如下: ngZone是对Zone.js的服务封装,Angular2会在每个task执行结束后触发更新。...由于事件系统用的Vue提供的,是可控的,我们再看下定时器下执行的情况: 打开控制台,点击按钮会发现依旧打印了0 0,有人可能就疑惑了Vue是不是跟Angular2一样也修改了异步方法的原生实现呢?...异步更新队列 每当观察到数据变化时,Vue就开始一个队列,将同一事件循环内所有的数据变化缓存起来。如果一个watcher被多次触发,只会推入一次到队列中。

    3.2K20

    JS事件

    当满足scrollHeight - scrollTop == clientHeight时,表明垂直滚动条滚动到底了 阅读知情同意书的小案例 onmousemove事件事件对象 获取鼠标的坐标 页面滚动条的归属者...获取对象的html内容 或 向对象插入html内容 我们可以通过 document.getElementById(‘aa’).innerHTML 来获取id为aa的对象的内嵌内容; 也可以对某对象插入内容,...当我们给a标签添加onclick事件处理函数并点击a触发其后, 如果相应JavaScript代码返回true,onclick事件处理函数就会认为这个链接呗点击了,同样的若返回false即会认为链接...://www.baidu.com” οnclick=” return false; "> Click Me 当点击a标签时,JavaScript代码返回值为false,故此链接默认行为未被触发...-- 默认禁用,除非将滚动条滑动到最底部 --> 我同意上面的协议 //首先绑定一个滚动条滚动的事件

    12.6K10

    微信小程序教学第四章第三节(含视频):小程序中级实战教程:详情-功能完善

    增加 下一篇 功能 增加 下一篇 的功能,我们需要在视图中绑定一个事件,来触发代码中的响应函数,此函数会调用接口,返回下一篇文章内容数据。...return null } }) } 大概介绍下这两个函数: 点击触发 next 函数,它会先调用 requestNextContentId,通过把当前文章的 lastUpdateTime...增加 分享 功能 调用小程序会对分享事件做监听,如果触发分享功能后,监听事件会返回一个对象,包含了分享出去的信息内容,并且可以分别对分享成功和分享失败做处理 <!...所以我们需要给分享按钮另外绑定一个点击事件,如果不支持的话,提示用户: notSupportShare () { // deviceInfo 是用户的设备信息,我们在 app.js 中已经获取并保存在...增加 返回列表 功能 我们需要在 detail.js 中增加一个返回列表的函数,然后视图中绑定触发事件 // detail.js 增加以下内容 Page({ back(){ wx.navigateBack

    900100

    Change Detection And Batch Update

    我们别急着下结论,我们知道应用程序状态的改变主要是下面三种情况引起的: Events - 点击按钮 Timers - setTimeout XHR - 从服务器获取数据 我们才测试了事件这一种情景,...如果我们不使用Angular1提供的事件系统、定时器和$http,如在jQuery事件中进行数据更新时,我们需要手动调用$apply。 Angular2 ?...会在每个task执行结束后触发更新。...Vue模板中每个指令/数据绑定都有一个对应的watcher对象,当数据变化时,会触发watcher重新计算并更新相应的DOM。...异步更新队列 每当观察到数据变化时,Vue就开始一个队列,将同一事件循环内所有的数据变化缓存起来。如果一个watcher被多次触发,只会推入一次到队列中。

    3.7K70

    Change Detection And Batch Update

    我们别急着下结论,我们知道应用程序状态的改变主要是下面三种情况引起的: Events - 点击按钮 Timers - setTimeout XHR - 从服务器获取数据 我们才测试了事件这一种情景,...如果我们不使用Angular1提供的事件系统、定时器和$http,如在jQuery事件中进行数据更新时,我们需要手动调用$apply。 Angular2 ?...会在每个task执行结束后触发更新。...Vue模板中每个指令/数据绑定都有一个对应的watcher对象,当数据变化时,会触发watcher重新计算并更新相应的DOM。...异步更新队列 每当观察到数据变化时,Vue就开始一个队列,将同一事件循环内所有的数据变化缓存起来。如果一个watcher被多次触发,只会推入一次到队列中。

    3.3K40

    HTML DOM的各种宽高、偏移位置的属性总结

    Event事件对象 1.clientX和clientY 这对属性是当事件发生时,鼠标点击位置相对于浏览器(可视区)的坐标,即浏览器左上角坐标的(0,0),该属性以浏览器左上角坐标为原点,计算鼠标点击位置距离其左上角的位置...3.offsetX和offsetY 这一对属性是指当事件发生时,鼠标点击位置相对于该事件源的位置,即点击该div,以该div左上角为原点来计算鼠标点击位置的坐标,如下所示: 可以看到,点击该div的靠近左上角处...offsetY 表示鼠标指针位置相对于触发事件的对象的 y 坐标。 mousemove事件是冒泡的,当里面的div触发mousemove事件时会向上冒泡,当冒泡到最外层div时调用事件处理程序。...任何一个事件的目标元素都是最开始触发事件的那个元素。...4.pageX和pageY 顾名思义,该属性是事件发生时鼠标点击位置相对于页面的位置,通常浏览器窗口没有出现滚动条时,该属性和event.clientX及event.clientY是等价的,但是当浏览器出现滚动条的时候

    1.6K30

    SNS项目笔记--手势Gestures

    移动开发与PC开发大相径庭,PC上最多的是鼠标点击事件,但是手机上面的手势事件却又很多,最常见的开发问题是处理父控件与子控件事件冲突问题,这就要我们十分了解手势了。...1、angular处理事件源码: 这里直接贴上angular源码地址:angular源码之hammer_gestures 这里又贴上该地址的源码以便说明: /** * @... 这是我们常见的写法,两个同时用click或者tap来完成点击事件的处理,在实际操作中造成事件冒泡,点击button,两个方法同时运行。... 由于错误写法1我们了解到,tap事件是触摸事件,并不是点击事件,在触发的时候会隔离事件冒泡,虽然不能一起使用,但是可以在click事件上阻止click触发,所以我们在子控件上使用...附上angular语法防止事件冒泡的文章: angular4 防止事件冒泡 ? timg.jpeg

    1.6K10

    Angular 中自定义 Video 操作

    上一篇文章是 Angular 项目实现权限控制。最近自己在网上看到别人使用 vue 进行自定义 video 的操纵。.../ 退出画中画 【安卓平板不支持,不建议使用】 经过时长 / 总时长 播放进度条功能:支持点击,拖拽进度 声音进度条功能:支持点击,拖拽进度 如图: 下面我们来一一实现: 这里的重点不在布局,我们简单来定义一下... 这里使用了 angular ant design,之前写了一篇相关文章,还不熟悉的读者可前往 Angular 结合 NG-ZORRO 快速开发 播放...,移动,松开的事件,对视频的播放时间和总事件进行相除,计算百分比。...声音进度条也是监听鼠标的点击,移动,松开。不过,这次我们处理的是已知声音 div 的高度。

    1.8K30

    微信小程序教学第四章第三节(含视频):小程序中级实战教程:详情-功能完善

    增加 下一篇 功能 增加 下一篇 的功能,我们需要在视图中绑定一个事件,来触发代码中的响应函数,此函数会调用接口,返回下一篇文章内容数据。...return null } }) } 大概介绍下这两个函数: 点击触发 next 函数,它会先调用 requestNextContentId,通过把当前文章的 lastUpdateTime...增加 分享 功能 调用小程序会对分享事件做监听,如果触发分享功能后,监听事件会返回一个对象,包含了分享出去的信息内容,并且可以分别对分享成功和分享失败做处理 <!...所以我们需要给分享按钮另外绑定一个点击事件,如果不支持的话,提示用户: notSupportShare () { // deviceInfo 是用户的设备信息,我们在 app.js 中已经获取并保存在...增加 返回列表 功能 我们需要在 detail.js 中增加一个返回列表的函数,然后视图中绑定触发事件 // detail.js 增加以下内容 Page({ back(){ wx.navigateBack

    36500

    前端高薪必会的JavaScript重难点知识:防抖与节流详解

    当我们滚动浏览器的滚动条时,会频繁触发scroll事件。我们通过监听浏览器scroll事件来断判断滚动条位置,如果滚动条滚动到页面的最底部,则就会加载更多信息。...因为滚动时会频繁触发scroll事件,就会造成频繁的判断滚动条位置。...而我们并不希望每次触发scroll事件都需要去判断滚动条的位置,来决定是否加载更多,我们希望能间隔一定时间(几百毫秒)再判断一次,然后决定是否加载更多。...滚动加载更多源理: 可视区的高度 + 滚动条滚动高度 >=文档高度 (整个滚动高度) 时就触发加载更多信息 未添加节流处理前的效果 scroll事件函数中的代码,在scroll事件触发时会频繁的被执行,...节流应用场景 监听滚动事件判断是否到页面底部自动加载更多 搜索联想功能 DOM元素的拖拽功能实现 射击游戏的 mousedown/keydown 事件(单位时间只能发射一颗子弹) 防止高频点击提交,防止表单重复提交

    1.9K00
    领券