首页
学习
活动
专区
圈层
工具
发布

linux(五)之vi编译器

这些按键均是普通的字符,   例如l是向右移动光标,相当于向右箭头键,k是向下移动光标,相当于向下箭头键。在编辑模式下,用户还可以利用一些特殊按键选定文字,然后再进行删除、或复制等操作。...仅键入命令:q时,如vi发现文本内容已被更改,将提示用户使用“:quit”命令退出。...$(即Shift+4):移动到当前行的结尾处 H(大写):使光标移动到屏幕的顶部 M(大写):使光标移动到屏幕的中间 L(大写):使光标移动到屏幕的底部 Ctrl+b:上滚一屏。...撤消对一行的更改:输入U来撤消你对一行所做的所有更改,这个命令只有在你没将光标移动到该行以外时才生效。...为新的字符串new::s/old/new/g 在两行内替换所有的字符串old为新的字符串new::#,#s/old/new/g 在文件内替换所有的字符串old为新的字符串new::%s/old/new/g 进行全文替换时询问用户确认每个替换需添加

4K80

Android中文API——ScrollView

这个视图必须在调用这个函数之前做好了整体布局。当实现一个视图时,不需要继承这个方法;相反,你应该实现onDraw(Canvas)方法。...参数 canvas 绘制视图的画布 public boolean executeKeyEvent (KeyEvent event) 当接收到key事件时,用户可以调用此函数来使滚动视图执行滚动,类似于处理由视图体系发送的事件...(译者注: 如何监听android的屏幕滑动停止事件) 参数 velocityY Y方向的初始速率。正值表示手指/光标向屏幕下方滑动,而内容将向上滚动。...此方法将视图滚动到顶部或者底部,并且将焦点置于新的可视区域的最顶部/最底部组件。若没有适合的组件做焦点,当前的ScrollView会收回焦点。...约定:当重写此方法时,你必须调用setMeasuredDimension(int, int)来保存当前视图view的宽度和高度。

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

    打造聊天框丝滑滚动体验:AI 聊天框的翻转之道

    我们需要开发一个类似微信聊天框的交互体验:每当聊天框中展示新消息时,需要将聊天框滚动到底部,展示最新消息。...如果在 web 什么也不做,聊天体验可能是这样的,需要用户手动滚动到最新消息:试想一下如何在 web 中实现微信的效果。每当聊天框中接收到新消息时,都需要调用滚动方法滚动到消息底部。...如果仍使用 scrollIntoView 来滚动到底部,就需要监听消息体的变化,每次消息更新时都要通过 JavaScript 调用一次滚动方法,会造成一些问题:频繁的 JavaScript 滚动调用。...滚动条怎么跑到左边,并且滚动行为和鼠标滚轮的方向反了,滚轮向上滚,聊天框却向下滚。...不需要对聊天框和消息体再进行旋转操作,也不需要反转滚动条的行为。以上两种方法都存在一个相同的问题,当一开始聊天消息还很少时,聊天消息也会紧贴着底部,顶部会留出一片空白。

    3.4K21

    一个快速的 Vue3 无限滚动组件

    无限滚动组件是在用户向下滚动页面时加载新内容,而不是将其分成多个页面。 它们对于特定类型的内容(例如用户生成的内容)非常有效。 以下是无限滚动的示例。...你可以阅读我之前分享的一篇文章《无限滚动与分页哪个用户体验更好?如何正确使用它们》,在这里,我只简单的总结一下它们的有缺点。...那么,现在让我们继续进行激动人心的部分:无限滚动! 4. Vue3 无限滚动 现在我们已经完成了所有设置,当用户向下滚动到内容底部时,我们可以开始加载更多数据。...以下代码通过检查我们内容的底部是否在屏幕上可见来工作。如果是,我们调用我们的方法来加载更多内容!...当我们向下滚动到当前内容的底部时,应该会自动加载新内容。让我们看看我们有什么。 无限滚动组件的可能扩展 这只是创建Vue3无限滚动组件的介绍。有很多不同的方向可以改进它。

    3K20

    Flutter | 超简单仿微信QQ侧滑菜单组件

    需求分析 老套路,先分析一下需求: 1.首先可以滑出菜单2.菜单滑动到一定距离完全滑出,未达到距离回滚3.菜单数量、样式随意定制4.菜单点击回调5.菜单展开时,点击 item 收回菜单(见QQ) 代码实现...首先可以滑出菜单 最基本的,菜单要能滑的出来,我们思考一下,如何能在屏幕外面放置 Widget,并且还能滑动?...菜单滑动到一定距离完全滑出,未达到距离回滚 这个效果就需要监听滑动距离和手势了。 如果滑动距离大于所有 menu 宽度的 1/4,那就全都滑出来,如果不到的话,就回滚回去。...菜单数量、样式随意定制 这个其实很简单,让「用户」来传入就好了, 我只需要控制 menu 的宽度。...•translucent:当点击组件透明区域时,可以对自身边界内及底部可视区域都进行命中测试,这意味着点击顶部组件透明区域时,顶部组件和底部组件都可以接收到事件。

    2.7K32

    3分钟搞定图片懒加载

    随着滚动条的向下滚动,bound.top会越来越小,也就是图片到可视区域顶部的距离越来越小,当bound.top 时,图片的上沿应该是位于可视区域下沿的位置的临界点,再滚动一点点...当向下滑动的时候,从Network面板可以看到,剩下的图片是一个个加载的。 可能有人疑问为什么第一次加载了4张,而不是3张?...思路:当页面滚动的时候需要去监听scroll事件,在scroll事件的回调中,判断滚动条是否滚动到最底部,如果是,则将将图片的 src 属性设置为data-src的值。...当page=0时,会随机返回一页数据,page>=1时会返回相应页码的数据。 源代码: 当滚动到20张图的底部的时候,就会发出ajax请求,请求下一页数据。 ? 至此本文完,有疑问可以在评论区随时交流哈。

    3K20

    后端接口一次返回10万条数据,前端应该如何处理?

    一些平台的博主经常分享这种问题如何处理,说实话,这种问题工作中几乎不可能遇到,数据都会进行分页处理,但不排除一些特殊的场景,比如要导出所有数据或是大屏慕展示所有数据什么的,如果遇到这种场景该如何处理呢?...通过 setTimeout 进行分页渲染; 一个简单的优化方法是对数据进行分页。假设每个页面都有limit记录,那么数据可以分为Math.ceil(total/limit)个页面。...该方法将回调作为要在重绘之前调用的参数。 2.4. ...延迟加载; 虽然后端一次返回这么多数据,但用户的屏幕只能同时显示有限的数据。所以我们可以采用延迟加载的策略,根据用户的滚动位置动态渲染数据。...要获取用户的滚动位置,我们可以在列表末尾添加一个空节点空白。每当视口出现空白时,就意味着用户已经滚动到网页底部,这意味着我们需要继续渲染数据。

    1.6K10

    医疗数字阅片-医学影像-Lodash 是一个一致性、模块化、高性能的 JavaScript 实用工具库。_.throttle(func, , [option

    可以提供一个 options 对象决定如何调用 func 方法, options.leading 与|或 options.trailing 决定 wait 前后如何触发。 ...基于 AJAX 请求的自动完成功能,通过 keypress 触发 为什么用户还在输入的时候,每隔50ms就向服务器发送一次 AJAX 请求?...节流阀实例 无限滚动 用户向下滚动无限滚动页面,需要检查滚动位置距底部多远,如果邻近底部了,我们可以发 AJAX 请求获取更多的数据插入到页面中。...我们心爱的 _.debounce 就不适用了,只有当用户停止滚动的时候它才会触发。只要用户滚动至邻近底部时,我们就想获取内容。 使用 _.throttle 可以保证我们不断检查距离底部有多远。...requestAnimationFrame:可替代 throttle ,函数需要重新计算和渲染屏幕上的元素时,想保证动画或变化的平滑性,可以用它。注意:IE9 不支持。

    3.1K20

    【Python爬虫实战】全面掌握 Selenium 的 IFrame 切换、动作链操作与页面滚动技巧

    前言 在使用 Selenium 进行网页自动化测试或数据抓取时,我们经常会遇到需要操作 iframe、模拟复杂的 用户交互动作,以及处理 动态加载页面 的情况。...因此,当元素位于iframe中时,需要先切换到该iframe,否则Selenium会找不到该元素。...三、页面滚动 在使用 Selenium 进行自动化测试或网页数据抓取时,页面滚动是非常重要的一部分,特别是在处理动态加载内容,如无限滚动页面时。...以下是与 页面滚动 相关的主要内容和代码示例: (一)页面滚动的必要性 某些网页会使用 AJAX 技术动态加载数据,用户需要不断向下滚动才能看到更多内容。...2. document.body.scrollHeight:获取页面的总高度,常用于滚动到底部。 按像素滚动页面 有时需要逐步滚动页面,以模拟更接近用户的行为。可以指定像素值进行滚动。

    3K11

    【兼容性】H5滚动穿透解决方案

    为什么会觉得这个这个行为是合理性,我的理解是 用户产生滚动行为,浏览器就必须要响应这个行为,产生滚动的反馈,这才是正常的。...) { return true; } e.preventDefault(); }, { passive: false } ); 但是对待白名单的元素放开限制之后,当元素滚动到顶部和底部的时候...之前我们说了,浏览器需要尽可能响应滚动行为,element 滚到两端 element 滚不了,那我就滚 document 所以我们最好监听 element 滚到 顶部和 底部的时机,继续禁止滚动行为 var...stopPropagation() 之后,不仅元素可以滚了,还会导致滚动穿透(毕竟只要元素能滚就能发生穿透) 但是document 还是不会滚动的 3滚动穿透的触发条件 一次没有抬起的滚动行为(手没有离开屏幕...)导致元素滚动到顶部或者 底部之后,如果手还在屏幕上往两端滑,并不会触发滚动穿透 如果你把元素滚动到 两端不可滚之后,抬起手,再按下去,往不可滚的方向移动,此时才会发生 滚动穿透 之前我们说了,滚动响应有两种对象

    7.1K20

    滚动穿透的6种解决方案【已自测】

    需要我们能确保用户在不发生上滑页面滚动屏幕的情况下就能触发弹层出现,就不会出现我上边说的问题。...因此还需要我们对弹层的可滚动区域的滑动事件做监听: 第一种情况,若向上滑动时,到达底部;或者第二种情况,若向下滑动时,已到顶部。 这两种情况任意一种发生时,就阻止滑动事件。...但是同样的问题是,需要判断滚动到顶部和滚动到底部的时候禁止滚动。否则,就和第二条一样,触碰到上下两端,弹窗可滚动区域的滚动条到了顶部或者底部,依旧穿透到body,使得body跟随弹窗滚动。...、后期touchmove里边获取每次的e.targetTouches[0].clientY与第一次的进行比较,可以得出用户是上滑还是下滑手势。...5、可能需要多考虑的一点是,当用户一直上翻到底或者一直下拉到顶时,做一下极值的判断和限制。 6、最后把本次移动到的点y2替换给y1,根据手势移动实时更新当前手势的地址。

    14.7K31

    jQuery 自定义网页滚动条样式插件 mCustomScrollbar 的介绍和使用方法

    callbacks:{ onScroll:function(){} }:自定义回调函数在滚动中执行 Demo 同上 callbacks:{ onTotalScroll:function(){} }:当滚动到底部的时候调用这个自定义回调函数...Demo 同上 callbacks:{ onTotalScrollBack:function(){} }:当滚动到顶部的时候调用这个自定义回调函数 Demo 同上 callbacks:{ onTotalScrollOffset...:Integer }:设置到达顶部或者底部的偏移量 像素单位 callbacks:{ whileScrolling:function(){} }:当用户正在滚动的时候执行这个自定义回调函数 callbacks...");:滚动到顶部(垂直滚动条) $(selector).mCustomScrollbar("scrollTo","bottom");:滚动到底部(垂直滚动条) $(selector).mCustomScrollbar...如果想使其重新可用,调用 update方法。disable 方法使用一个可选参数(默认 false)你可以设置 true 如果你想重新让内容区域滚动当 scrollbar 不可用时。

    16.6K30

    关于ajax学习笔记

    _JSONtoURLparams(json)); } } })(); 五、关于ajax缓存问题 当Ajax第一次发送请求后,会把请求的URL和返回的响应结果保存在缓存内,当下一次调用...Ajax发送相同的请求时,注意,这里相同的请求指的是URL完全相同,包括参数,浏览器就不会与服务器交互,而是直接从缓存中把数据取出来,这是为了提高页面的响应速度和用户体验。...5.1 如何避免 ajax 缓存问题 方法1:随机数 //随机数,我们不要0....的示例:瀑布流 要实现2个地方: 滚动到底部判断(包含视口的底部和总的底部) 瀑布流里面的内容需要错位显示 8.1 滚动到底部判断 我们需要知道: 总文档高度 已经滚动的高度 视口高度,通过$(document...).height(); 获取,视口底部来触发ajax 获取下一页的数据 总文档高度-已经卷动高度-视口高度 动到底了,滚动到文档底部就停止 ajax 请求。

    2.2K20

    06-移动端开发教程-fullpage框架

    比如:全屏滑动案例 下面我们就介绍一下jQuery的fullPage.js的如何使用及常用的配置。...窗口缩放时自动调整。 可设置滚动宽度,背景颜色,滚动速度,循环选项,回调,文本对齐方式等。...字符串 bottom 左右滑块的项目导航的位置,可选 top 或 bottom controlArrowColor 字符串 #fff 左右滑块的箭头的背景颜色 loopBottom 布尔值 false 滚动到最底部后是否滚回顶部...loopTop 布尔值 false 滚动到最顶部后是否滚底部 loopHorizontal 布尔值 true 左右滑块是否循环滑动 autoScrolling 布尔值 true 是否使用插件的滚动方式...一般情况下都是用户进入某个屏的时候,动画开始启动入场,离开的时候启动出场(可以省略),然后下一屏开始入场。

    6.4K50

    06-移动端开发教程-fullpage框架

    比如:全屏滑动案例 下面我们就介绍一下jQuery的fullPage.js的如何使用及常用的配置。...窗口缩放时自动调整。 可设置滚动宽度,背景颜色,滚动速度,循环选项,回调,文本对齐方式等。...字符串 bottom 左右滑块的项目导航的位置,可选 top 或 bottom controlArrowColor 字符串 #fff 左右滑块的箭头的背景颜色 loopBottom 布尔值 false 滚动到最底部后是否滚回顶部...loopTop 布尔值 false 滚动到最顶部后是否滚底部 loopHorizontal 布尔值 true 左右滑块是否循环滑动 autoScrolling 布尔值 true 是否使用插件的滚动方式...一般情况下都是用户进入某个屏的时候,动画开始启动入场,离开的时候启动出场(可以省略),然后下一屏开始入场。

    6.6K90

    微信小程序之上拉加载与下拉刷新

    在移动端,随着手指不断向上滑动,当内容将要到达屏幕底部的时候,页面会随之不断的加载后续内容,直到没有新内容为止(我们是有底线的-o-),我们称之为上拉加载,从技术角度来说,也可以称之为触底加载。...感觉实现起来也不难,主要就是其中的“监听页面是否被滚动到底部”如何来实现?...,以及每次在上拉触底触发onReachBottom时被调用。...,当处理完成后,记得一定要调用wx.stopPullDownRefresh来终止下拉刷新。...另外,下拉刷新的事件也可以通过调用APIwx.startPullDownRefresh触发,效果与用户手动下拉刷新一致。 其他 上面介绍的上拉加载和下拉刷新,都是针对整个Page的。

    4.8K20

    开发 | 一个 Android 开发者的小程序开发之旅

    当用户创建的接龙类型是指定群成员参与时,指定的群就是第一个转发到的群。而成员也只有通过这个群的分享进入小程序,才可参与接龙。 下面,我所说的这些情况,都是如何获取到群 ID 的。...接龙列表页面 从设计图可以看到,新的成语在成语接龙列表的底部,类似微信聊天中,新消息都在屏幕下方的效果。 但是,列表都是默认置顶的,用户进入一个接龙,很有可能需要划很久才能到最新一条接龙。...如果要实现滑动到顶部,进行「加载更多」的操作,可以用上 bindscrolltoupper 这个属性。当屏幕滑动到顶部时,这个属性所绑定的事件就会被触发。...在 Android 开发里,有一个叫 FloatActionButton 的控件,当列表滚动时,这个控件可以向下移动隐藏。我尝试在小程序里实现类似的效果。...我觉得遮挡其实只对列表最底部有影响,所以当列表滚到底部时隐藏就好了;在底部重新发生滚动时,再重新显示按钮。

    86420

    仿腾讯课堂固定滚动列表ReactNative组件

    滚动条到底部了,视频播发控件的区域距离屏幕顶部还有80。...一个是怎么判断手势滑动以及外层滚动容器到底部和内层滚动到顶部? 第二个是寻找滚动组件并通知内层滚动组件开始滚动?...ViewGroup的dispatchTouchEvent方法,然后其内部调用onInterceptTouchEvent()方法来判断是否拦截该触摸事件,若拦截该事件则调用ViewGroup的onTouchEvent...而这个方法会随着手势不断调用,这时候聪明的你想到了啥?根据手触摸屏幕的y坐标差来判断手势往上还是往下。...&&向上滑:不拦截 RNFixScrolView未到底部&&向上滑:拦截 RNFixScrolView未到底部&&向下滑&&子ScrollView已到顶部:拦截 RNFixScrolView已到底部

    5.9K70

    【盟友分享】vim学习之路-vim基本操作

    移动到第n行,或者用:n也可 { 上一段,}下一段 (空行区分) [ 函数开始,]函数结束(c文件有效) % 跳到匹配的括号处 滚屏操作: CTRL-U使文本向下滚动半屏。...相当于显示文本的窗口向上滚半屏。光标所处的行数随滚屏而改变。 CTRL-D使文本向上滚动半屏。相当于显示文本的窗口向下滚半屏。光标所处的行数随滚屏而改变。 CTRL-E使文本向上滚动一行。...CTRL-Y使文本向下滚动一行。光标所处的行数不变。 CTRL-F 向前滚动一整屏。滚动后光标处于第一行。 CTRL-B向后滚动一整屏。滚动后光标处于最后一行。 zz把当前位置处于屏幕的正中央。...zt 把当前位置处于屏幕的顶端。助记:top。 zb 把当前位置处于屏幕的底端。助记:bottom。...后添加外部命令 查找 :/ 在/后添加要查找的内容,进入查找时,按n查找下一个,N查找上一个

    2.7K60
    领券