Qtextbrowser的滚动条滚动触发事件

想实现一个功能:
textbrowser中有数据,并且在不断刷新数据,此时我通过鼠标拉动滚动条到某一行,进行数据的查看时,我不希望页面一直在刷新,并且跳到了最底部。而是界面不再刷新。直到我将滚动条拉到底部后,继续恢复刷新机制。注意:不刷新阶段,虽然不显示数据,但是最后恢复刷新时,该段时间的数据仍要显示出来。
具体办法:
1、通过重写QTextBrowser控件,增加一个刷新标识符
2、在有鼠标拉动滚动条时,触发事件,若拉到最底部,则将标识符置为true,否则置为false
3、重写append事件,增加标识符判断,再进行刷新

from PyQt5 import QtWidgets, QtGui
import sys

class MyTextBrowser(QtWidgets.QTextBrowser):
    def __init__(self, parent=None):
        super().__init__(parent)
        # self.verticalScrollBar().valueChanged.connect(self.on_scroll) #不可用,界面数据填充满了也会导致滚动条事件不断执行
        self.fresh_flag = True
        self.verticalScrollBar().sliderMoved.connect(self.on_scroll)  # 只有鼠标拖动才响应

    def on_scroll(self):
        if self.verticalScrollBar().value() == self.verticalScrollBar().maximum():
            print("滚动条滚动到底部")
            self.fresh_flag = True
        else:
            print("滚动条没有滚动到底部")
            self.fresh_flag = False

    def append(self, text: str) -> None:
        if self.fresh_flag:
            super().append(text)
 
app = QtWidgets.QApplication(sys.argv)
text_browser = MyTextBrowser()
text_browser.show()
i = 100
while i > 0:
    i = i - 1
    text_browser.append(str(i))
sys.exit(app.exec_())

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue中,当滚动条滑动到某个元素的底部时,可以通过监听滚动事件(通常是`scroll`事件)来触发自定义的回调函数。这种行为通常在需要加载更多内容或者自动滚动到特定位置时使用。 以下是一个简单的例子,展示如何在Vue组件中监听滚动条滑动到底部的事件: ```html <template> <div ref="scrollElement" :style="{ height: 'calc(100vh - 100px)' }"> <!-- 假设这是你的可滚动区域 --> <div v-for="item in items" :key="item.id">{{ item.content }}</div> <!-- ... --> </div> </template> <script> export default { data() { return { items: [], // 其他数据... }; }, mounted() { this.$refs.scrollElement.addEventListener('scroll', this.handleScroll); }, methods: { handleScroll() { if ( this.$refs.scrollElement.scrollHeight - this.$refs.scrollElement.scrollTop === this.$refs.scrollElement.clientHeight ) { // 当滚动到底部时执行的代码 this.loadMoreItems(); // 加载更多数据的方法 } }, loadMoreItems() { // 在这里实现加载更多数据的逻辑 }, }, beforeDestroy() { this.$refs.scrollElement.removeEventListener('scroll', this.handleScroll); }, }; </script> ``` 在这个例子中,我们首先使用`ref`属性为可滚动区域添加了一个引用,然后在`mounted`生命周期钩子中添加了滚动事件监听器。当滚动到底部时,`handleScroll`方法会被调用,检查滚动条距离底部的距离是否等于滚动区域的高度,如果是,则说明已到达底部,执行`loadMoreItems`方法加载更多内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值