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

HTML 面试要点:History 和 Hash 路由方式

# 前端路由实现方法 路由需要实现以下功能: 当浏览器地址变化时,切换页面; 点击浏览器【后退】、【前进】按钮时,网页内容跟随变化; 刷新浏览器,网页加载当前路由对应的内容。...散列值不会随请求发送到服务器端,所以改变 hash,不会重新加载页面 监听 window 的 hashchange 事件,当散列值改变时,可以通过 location.hash 来获取和设置 hash.../ 请求到服务器,请求完毕之后设置散列值为 #/home,此时触发 onhashchange 事件 当值改变浏览器地址栏 URL 的哈希部分,按下回车,浏览器不会发送任何请求到服务器,只是设置散列值修改...() 移动到上一个网址,相当于点击浏览器后退键,该方法对于第一个访问的页面无效 注意移动到以前访问的页面时,页面通常是从浏览器缓存中加载,而不是重新请求服务器发送新的网页 History.forward...,该事件不会触发 页面第一次加载时,浏览器不会触发 popstate 事件

83220

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

overflow属性 监听回调 设置了 preventDefault 已经滚动到底端或顶端 为什么会觉得这个这个行为是合理性,我的理解是 用户产生滚动行为,浏览器就必须要响应这个行为,产生滚动的反馈,这才是正常的...,这样就可以避免页面的跳动,但是直接给 html 设置 absolute 风险太大,容易埋坑,不太建议大项目使用,小应用还是可以的,我在需求的小活动页7就使用过这种方式 5禁用页面滚动 除了在 css...之前我们说了,浏览器需要尽可能响应滚动行为,element 滚到两端 element 滚不了,那我就滚 document 所以我们最好监听 element 滚到 顶部和 底部的时机,继续禁止滚动行为 var...一次没有抬起的滚动行为(手没有离开屏幕)导致元素滚动到顶部或者 底部之后,如果手还在屏幕上往两端滑,并不会触发滚动穿透 如果你把元素滚动到 两端不可滚之后,抬起手,再按下去,往不可滚的方向移动,此时才会发生...滚动穿透 之前我们说了,滚动响应有两种对象,element 和 document 从这里可以意识到,单次的滚动行为 只会绑定一个滚动对象,不会切换响应对象 只是在开始滚动的时候,浏览器会根据情况,选择响应滚动的对象

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

    控制页面的滚动:自定义下拉到刷新和溢出效果

    (橡皮筋效果),使用overscroll-behavior-y: none: 完整Demo 总结 CSS overscroll-behavior属性允许开发人员在达到内容的顶部/底部时覆盖浏览器的默认溢出滚动行为...使用该案例包括禁用移动设备上的“拉动到刷新”功能,消除过度滚动发光和橡皮筋效果,并防止页面内容在模态/叠加层下滚动 背景 滚动边界和滚动链接 滚动是与页面交互的最基本的方式之一,但是由于浏览器的诡异默认行为...滚动由父容器占领;例子中的主页面本身 被证实这种行为称为滚动链接;滚动内容时浏览器的默认行为。通常情况下,默认设置非常好,但有时候这并不理想,甚至不可预料。...这些变通办法在滚动性能方面具有良好记录的负面影响 引入overscroll行为 overscroll-behavior属性是一个新的CSS功能,用于控制当你过度滚动容器(包括页面本身)时发生的情况。...(聊天窗口下的内容也会滚动) 页面重叠场景 下面”方案的另一个变动就是是当你看到内容在固定位置叠加后滚动时。一个死的样品overscroll行为是为了!浏览器试图帮助,但它最终使网站看起来越来越多。

    3.5K20

    HashMap源码解析

    那么这时就会有人想,在Java中有没有一种集合,即检索元素的速度快,删除元素的速度也快呢?...所以我们在日常开发时,为了提高HashMap的运行效率,要尽量的必免发生散列冲突的现象。...解决的办法就是增加HashMap中桶的数量,在Java中HashMap的默认桶的数量为16,也就是底层数组的大小为16。如果我们设置的桶的数量不够存储元素时,散列表就会执行再散列。...在HashMap中实际上并不是在散列表中已经满了的情况下才进行再散列的,而是有一个加载因子来决定什么时候进行再散列的。在HashMap中默认的加载因子的值为0.75。...如果我们保存元素时,元素的key相同,则底层会直接把后调用put方法的value覆盖前一次put的value。

    57110

    JavaScript(进阶)

    判断滚动条是否滚动到底 垂直滚动条 scrollHeight - scrollTop = clientHeight 1 复制 ---- # 文档的加载 浏览器在加载一个页面时,是按照自上向下的顺序加载的...(); }; /* * 当我们拖拽一个网页中的内容时,浏览器会默认去搜索引擎中搜索内容, * 此时会导致拖拽功能的异常,这个是浏览器提供的默认行为, * 如果不希望发生这个行为...} /* * 使用addEventListener()方法绑定响应函数,取消默认行为时不能使用return false * 需要使用event来取消默认行为event.preventDefault...如果浏览器有滚动条,滚动条会随之滚动, * 这是浏览器的默认行为,如果不希望发生,则可以取消默认行为 */ return false; }; //为火狐绑定滚轮事件 bind(element...,属于onkeydown的默认行为 //如果在onkeydown中取消了默认行为,则输入的内容,不会出现在文本框中 return false; } }; 1 2 3 4 5 6 7 8 9 10

    1.5K20

    mysql事务-redoundo log

    但是会面临一些问题: 刷新一个完整的数据页太浪费了:有时候我们仅仅修改了某个页面中的一个字节,但是我们知道在InnoDB中是以页为单位来进行磁盘IO的,也就是说我们在该事务提交时不得不将一个完整的页面从内存中刷新到磁盘...事务提交时: 在事务提交时可以不把修改过的Buffer Pool页面刷新到磁盘,但是为了保证持久性,必须要把修改这些页面对应的redo log刷新到磁盘。...1也是innodb_flush_log_at_trx_commit的默认值。 2:当该系统变量值为2时,表示在事务提交时需要将redo日志写到操作系统的缓冲区中,但并不需要保证将日志真正的刷新到磁盘。...,就会将该变量的值刷新到系统表空间的页号为5的页面中一个称之为Max Trx ID的属性处,这个属性占用8个字节的存储空间 当系统下一次重新启动时,会将上边提到的Max Trx ID属性加载到内存中,将该值加上...undo log 的记录, 如果发生回滚就只对上一步进行回滚 将被删除记录从正常链表移动到垃圾链表中(备注: 当一个页被回收足够多的垃圾链表, 默认 50% 阈值会发生页合并) update undo

    66810

    Rails布局和视图渲染

    这里渲染的就是 app/views/books/index.html.erb 使用render方法 render 方法的行为有多种定制方式,可以渲染Rails模板的默认视图、指定的模板、文件、行间代码或者什么也不渲染...指定控制器的布局 在控制器中使用 layout 声明,可以覆盖默认使用的布局约定: class ProductsController < ApplicationController layout...URL发起新请求: redirect_to photos_url 可以使用 redirect_back 把用户带回他们之前所在的页面,页面地址从 http_referer 中获取,不过浏览器不一定会设定...,或者符号形式,选项是一个散列,指定首部的名称和对应的值 head :bad_request head :created, location: photo_path(@photo) 布局的结构 静态资源标签辅助方法..." %> 文件名必须指定图像的拓展名 同样可以通过散列指定HTML属性,另外如果没有 alt 属性, Rails会使用图片的首字母大写的文件名(去掉拓展名)。

    3.4K30

    JS事件篇

    时,表明垂直滚动条滚动到底了 阅读知情同意书的小案例 onmousemove事件和事件对象 获取鼠标的坐标 页面滚动条的归属者 解决浏览器兼容性常使用以下写法 div跟随鼠标移动 事件的冒泡和事件对象event...替代 取消滚动条随滚轮移动的默认行为 键盘事件 浏览器对象模型---navigator 通过 属性名 in 对象 可以判断对应的属性在当前对象中是否存在 浏览器对象模型---History 浏览器对象模型...JS修改元素样式的一些思考 JSON JSON字符串转化为JS对象 JS对象转换为JSON字符串 eval函数 ---- window.onload:事件 浏览器加载一个页面时,是按照自上而下的顺序加载的...,读取到一行就运行一行,如果将script标签写到页面上边,在代码执行的时候,页面还没有完全加载 window.onload事件会在整个页面加载完成之后,才会触发,将对应的script代码,写在里面,可以确保...script代码可以在页面加载完成之后,才会执行 <!

    12.6K10

    数据结构(9)-- 哈希表 unordered_map

    那还有没有更好一点的办法呢?...那么,有没有办法在得到O(1)的查找效率的同时、又不付出太大的空间代价呢? 有,就是本篇讲的哈希表了。 很简单,我们把你的车牌号看作一个8位36进制的数字;为了方便,我们可以把它转换成十进制。...---- 加载因子 无论如何,哈希表中,碰撞无法绝对避免。 当碰撞发生时,就不得不使用开链表法或再散列法存储冲突数据;而这必将影响哈希表的性能。...我们前面提到过,当遇到这种冲突/碰撞时,为了避免彼此覆盖,这些数据就要存在链表中(或者再散列后存在同一个哈希表中)。...解决方案也很简单: 1、提高哈希函数复杂度,想办法加入随机性(相当于每次使用一个不同的哈希函数),避免被人轻易捕捉到弱点 2、不要用开链表法存储冲突数据,采用“再散列法”,并且使用不同的哈希函数再散列

    1.1K11

    移动端H5坑位指南

    -- 保存网站到桌面时添加图标且清除默认光泽 --> 针对其他浏览器配置 贴一些其他浏览器较零散且少用的配置...当页面包含多个滚动区域时,滚完一个区域后若还存在滚动动量则会将这些剩余动量传播到下一个滚动区域,造成该区域也滚动起来。这种行为称为滚动传播。 若不想产生这种奇怪行为可直接禁止。...这种情况在Safari上特别明显,简单概括就是往返页面无法刷新。 往返缓存指浏览器为了在页面间执行前进后退操作时能拥有更流畅体验的一种策略,以下简称BFCache。...pageshow事件在每次页面加载时都会触发,无论是首次加载还是再次加载都会触发,这就是它与load事件的区别。pageshow事件暴露的persisted可判断页面是否从BFCache里取出。...在输入框聚焦时获取页面当前滚动条偏移量,在输入框失焦时赋值页面之前获取的滚动条偏移量,这样就能间接还原页面滚动条偏移量解决页面高度坍塌。

    3.5K10

    JavaScript 高级程序设计(第 4 版)- BOM

    window 对象在浏览器中有两重身份,一个是 ECMAScript 中的 Global 对象,另一个就是浏览器窗口的 JavaScript 接口。...,返回值单位为CSS像素 可以使用moveTo()和moveBy()移动窗口(依浏览器而定,这俩方法部分或全部被禁用) moveTo()接收要移动到的新位置的绝对坐标x和y moveBy()接收相对当前位置在两个方向上移动的像素数...# 导航与打开新窗口 window.open()可以用于导航到指定URL,也可以用于打开新浏览器窗口 接收四个参数:要加载的URL、目标窗口、特性字符串和表示新窗口在浏览器历史记录中是否代替当前加载页面的布尔值...q=javascript#contents 属性 值 说明 location.hash #contents URL散列值,如果没有则为空字符串 location.host www.wrox.com:80...hashchange 会在页面 URL 的散列变化时被触发,开发者可以在此时执行某些操作。 状态管理 API 则可以让开发者改变浏览器 URL 而不会加载新页面。

    1.2K10

    【python自动化】playwright长截图&切换标签页&JS注入实战

    caret Union["hide", "initial", None] 设置为"hide"时,截图将隐藏文本插入符。设置为"initial"时,文本插入符的行为不会改变。默认为"hide"。...caret Union["hide", "initial", None] 设置为"hide"时,截图将隐藏文本插入符。设置为"initial"时,文本插入符的行为不会改变。默认为"hide"。...caret Union["hide", "initial", None] 设置为"hide"时,截图将隐藏文本插入符。设置为"initial"时,文本插入符的行为不会改变。默认为"hide"。...目标网址页面展示 「实战需求」 1、使用playwright连接本地指定端口浏览器 2、通过浏览器在新标签页打开指定项目ID下的相关页面 3、页面分为左右两栏,可以分别滚动,需要滚动右侧栏,并且进行长截图...(含用户数据,免登陆,懒加载) 2、使用js在新标签页打开相关网址 3、切换至指定标签页 4、定位右侧栏,结合js滚动进行多图截取 5、使用PIL库进行多图拼接 注:本教程为示列代码,业务代码为方便阅读未进行封装

    2.8K20

    == 与equals和hashCode与equals

    当创建 String 类型的对象时,虚拟机会在常量池中查找有没有已经存在的值和要创建的值相同的对象,如果有就把它赋给当前引用。如果没有就在常量池中重新创建一个 String 对象。...hashCode()介绍 hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。...通过我们可以看出:hashCode() 的作用就是获取哈希码,也称为散列码;它实际上是返回一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。...hashCode()在散列表中才有用,在其它情况下没用。在散列表中hashCode() 的作用是获取对象的散列码,进而确定该对象在散列表中的位置。...它们也不一定是相等的 因此,equals 方法被覆盖过,则 hashCode 方法也必须被覆盖 hashCode() 的默认行为是对堆上的对象产生独特值。

    84720

    2023【美团】面试真题:

    2、HashMap 的底层数据结构是怎样的 ? JDK1.8 之前 JDK1.8 之前 HashMap 底层是 数组和链表 结合在一起使用也就是 链表散列。...解决办法:缓存空值的 KEY,这样第一次不存在也会被加载会记录,下次拿到有这个KEY。...在使用过程中,把最近使用的页面移动到队列头,最近没有使用的页面将被放在队列尾的位置l 使用一个哈希表,把页号作为键,把缓存在队列中的节点的地址作为值,只需要把这个页对应的节点移动到队列的前面,如果需要的页面在内存中...事务版本号 表的隐藏列 undo log read view 20、undo log 具体怎么回滚事务 ?...or 语句前后没有同事使用索引,当且仅当 or 语句查询条件的前后列均为索引时,索引生效。 组合索引,使用的不是第一列索引时候,索引失效,即最左匹配规则。

    34630

    中高级前端必须注意的40条移动端H5坑位指南 | 网易三年实践

    -- 保存网站到桌面时添加图标且清除默认光泽 --> 针对其他浏览器配置 贴一些其他浏览器较零散且少用的配置...当页面包含多个滚动区域时,滚完一个区域后若还存在滚动动量则会将这些剩余动量传播到下一个滚动区域,造成该区域也滚动起来。这种行为称为「滚动传播」。 若不想产生这种奇怪行为可直接禁止。...这种情况在Safari上特别明显,简单概括就是往返页面无法刷新。 「往返缓存」指浏览器为了在页面间执行前进后退操作时能拥有更流畅体验的一种策略,以下简称BFCache。...pageshow事件在每次页面加载时都会触发,无论是首次加载还是再次加载都会触发,这就是它与load事件的区别。pageshow事件暴露的persisted可判断页面是否从BFCache里取出。...在输入框聚焦时获取页面当前滚动条偏移量,在输入框失焦时赋值页面之前获取的滚动条偏移量,这样就能间接还原页面滚动条偏移量解决页面高度坍塌。

    4.4K22

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

    如果在 web 什么也不做,聊天体验可能是这样的,需要用户手动滚动到最新消息:试想一下如何在 web 中实现微信的效果。每当聊天框中接收到新消息时,都需要调用滚动方法滚动到消息底部。...通过监听数据变化频繁的执行滚动,基于浏览器单线程的设计,不可避免的会造成滚动行为的滞后,导致聊天体验不够丝滑。...自然列表:灵感来源聊天框接收到新消息时滚动到最新位置,总感觉这应该是一个很自然的行为,不需要这么多 Javascript 代码去实现滚动行为。...滚动条调整与滚动行为反转最核心的问题已经解决了,但总觉得哪里看起来怪怪的。滚动条怎么跑到左边,并且滚动行为和鼠标滚轮的方向反了,滚轮向上滚,聊天框却向下滚。...聊天框的父组件也完全不知道自己的子节点被转了又转。总结最后总结一下,我们通过两行 CSS 代码 + 反转滚动行为,利用浏览器的默认行为完美的实现了 AI 聊天框中的滚动体验。

    1.7K21

    vue-router的hash和history模式的区别

    为了达到这一目的,浏览器当前提供了以下两种支持: hash —— 即地址栏 URL 中的 # 符号(此 hash 不是密码学里的散列运算)。...它的特点在于:hash 虽然出现在 URL 中,但不会被包括在 HTTP 请求中,对后端完全没有影响,因此改变 hash 不会重新加载页面。...如果不想要很丑的 hash,我们可以用路由的 history 模式,这种模式充分利用 history.pushState API 来完成URL 跳转而无须重新加载页面。...SPA 虽然在浏览器里游刃有余,但真要通过 URL 向后端发起 HTTP 请求时,两者的差异就来了。尤其在用户手动输入 URL 后回车,或者刷新(重启)浏览器的时候。...history模式下Nginx配置 Nginx根目录部署: nginx 服务器的默认目录是 /usr/share/nginx/html,你需要将本地 dist 目录下的静态文件上传至该目录。

    1.6K20

    响应式设计

    首先,它告诉浏览器当解析 CSS 时将设备的宽度作为假定宽度,而不是一个全屏的桌面浏览器的宽度。其次当页面加载时,它使用 initial-scale 将缩放比设置为 100%。...当链接太小不好点击,或者用户想要把某个图片看得更清楚时,这个设置会阻止他们缩放页面。 # 媒体查询 媒体查询(media queries)允许某些样式只在页面满足特定条件时才生效。...在各大主流浏览器中,当用户缩放页面或者改变默认的字号时,只有 em 单位表现一致。以 px 或者 rem 单位为断点在 Safari 浏览器里不太可靠。...同时当用户默认字号改变的时候,em 还能相应地缩放,因此它更适合当断点。 在媒体查询里更适合用 em,em 是基于浏览器默认字号的(通常是 16px)。...浏览器会根据自身需要决定加载哪一个图片。

    2.1K10

    Linux环境下Nginx及负载均衡

    Tips: Ubuntu Server 版默认没有桌面,通过 SSH 连接到服务器 打开新终端,通过 SSH 连接到服务器,再使用 curl 127.0.0.1 命令返回页面源文件 打开客户端浏览器,...输入服务器 IP 地址 比较上面两步对应的操作日志有什么区别 刚才在 Ubuntu 默认的火狐浏览器打开 127.0.0.1 时的访问日志如图。...解决这个办法可以在 server_name 后面增加一个别名。...,在普遍会话较长的情况下推荐使用 散列(Hash):根据请求源的 IP 的散列来选择要转发的服务器,这种方式可以一定程度上保证特定用户能链接到相同的服务器 负载均衡算法: round:每个请求按时间顺序逐一分配到不同的后端服务器...:每个请求按访问 IP 的散列结果分配,每个访客固定访问一个后端服务器,可以解决 session 的问题 url_hash(第三方):每个请求按 URL 的散列结果分配,不同访客访问相同的服务器 ?

    1.8K30
    领券