- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先对不起我的英语不好。我会尽量让这个问题可以理解。这仅适用于教育机构:)
当您在 youtube 中观看视频并更改为相关视频中的另一个视频时。页面的很多部分没有更改。因此,如果您更改本地文件(服务器发送给您时下载到您的电脑的页面),您可以看到修改仍然存在。所以如果您删除 de youtube Logo 并访问另一个视频(通过单击相关视频)您会看到视频、标题、说明和相关视频发生变化,但没有标题。您可以在开发者控制台中看到(例如在 Opera 中),您可以查看它. 当我们点击新的相关视频时,它不会加载新页面。让我们解释一下图像
1:您选择标题的一个图标
2:您从中删除代码
3:点击另一个视频,标题还在修改中
我的观察:这可能是一个 ajax 重新加载方法,但是(据我所知)您不能更改浏览器栏的 url(出于安全原因)。那么 youtube 是如何实现这一点的呢?
PD:也许有一种新技术,这非常普遍。但我想知道如何做到这一点:)
最佳答案
这对于单页应用程序 (SPA) 来说非常典型。使用 HTML5 History API,页面脚本拦截 URL 的更改(只要它们在同一个域中),并使用 View Router 使用新的详细信息重新呈现页面,包括请求新数据。
因此,当您从一个视频开始并导航到另一个视频时,浏览器实际上并没有真正“导航”——正如您所说,它从 URL 获取新的视频 ID,从某些后端服务加载视频的元数据并呈现适当的页面。
YouTube 似乎是使用某些版本的 AngularJS 构建的(这很有意义,因为 Google 编写了 Angular 框架)所以如果您想了解更多信息,可以阅读如何构建 Angular 应用程序,但大多数现代 Web 应用程序都是基于类似的基础。这通常是一个好主意,因为与仅更新需要更改的位相比,重新加载整个页面既昂贵又缓慢。
关于javascript - Youtube 有趣的页面加载方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45972104/
文档:https://www.xfyun.cn/doc/spark/PPTGeneration.html 价格方面提供了免费1000点的额度,生成一次是10点,正好10
我有一个工具按钮和一个分配给它的操作。但该操作没有点击事件,也没有点击代码。因此该按钮被禁用,如何将其更改为启用? 谢谢! 最佳答案 当某个操作没有 OnExecute 处理程序时,该操作始终处于禁用
我有一个 C 程序,它初始化两个结构并尝试打印它们的值。请参阅下面的代码。 #include #include typedef struct node{ int data; struc
我在回答 this question当我想到这个例子时: #include void func(int i); void func(); int main (){ func(); r
这些bug可能够你喝一壶的。 1、被断言(assert)包含的代码 常发生在切换到release版本时,执行结果乖乖的,最终查找结果是assert括号里的代码在release下是不执行的。
我正在谈论一个独立的对象,稍后我想使用 saveOrUpdate() 进行更新。 我们如何同时设置 null 和clear()引用的集合? A[1:1]B[1:M]C B 到 C 的引用可以为空,这意
我最近完成了 Marjin Haverbeke 的书“Eloquent Javascript, Second Edition”中的一项挑战。 One had to create此控制台输出使用 for
我写了一个 HtmlHelper 表达式,我花了很多时间将标题标签放入我的下拉列表中,如下所示: public static HtmlString SelectFor( thi
你知道有哪些开放的软件项目有特别有趣/写得很好的单元测试吗? 编写单元测试对我来说通常感觉很奇怪,因为它似乎太随机、太密集、太稀疏,……阅读一些现实世界的例子(而不是书籍、图书馆示例代码等)会很棒。
我有一个我目前正在使用的 Silverlight 应用程序,它为其 MVVM 框架实现了 Caliburn.Micro。一切正常,但我注意到一些绑定(bind)中的一些有趣之处。我拥有的是处理应用程序
我通过 swscale 运行 png 图像数据以获取 YUV420P 数据,然后使用 MSMPEG4V1 编解码器对该帧进行编码,从而在 iPhone 上对一些视频进行编码。在 api 文档中,avc
我写了一个页面,发现 addEventListener("loadedmetadata",fun) 在 firefox 上运行不正确 我正在尝试修复一个旧软件的错误。在加载视频和页面时,该软件尝试在页
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我是一名优秀的程序员,十分优秀!