- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在优化一个网站,主要目的是提高网页的整体下载时间。我一直在应用 Yahoo Developer Network 的 "Best Practices for Speeding Up Your Web Site" 推荐的技术。 .
现在,统计数据显示我们有很多访问者首先通过以下方式访问该网站:
独立的搜索引擎页面HTTP 错误处理程序——即我们自定义的“404 Not Found”页面其他杂项独立页面
请注意,这些所谓的“独立页面”独立于负责网站页面布局和结构的模板系统而存在。它们有自己的样式表和脚本(因此也独立于模板系统的 CSS 和 JS 文件而存在。
现在,这些页面类型更多的是中间页面而不是内容页面。它们的一般用途的一个很好的例子是 reference landing page。 .我认为使用类似post-onload 的技术来“准备好”用户的缓存,为他们的下一步行动做好准备是个好主意(这几乎总是是一部分主模板系统)。
Steve Sounders 的脚本是:
<script>
function doOnload() {
// Do the downloading awhile AFTER the onload.
setTimeout("downloadComponents()", 1000);
}
window.onload = doOnload;
// Download external components dynamically using JavaScript.
function downloadComponents() {
downloadCSS("http://stevesouders.com/hpws/testsm.css?t=1388138263");
downloadJS("http://stevesouders.com/hpws/testsma.js?t=1388138263");
downloadJS("http://stevesouders.com/hpws/testsmb.js?t=1388138263");
downloadJS("http://stevesouders.com/hpws/testsmc.js?t=1388138263");
}
// Download a stylesheet dynamically.
function downloadCSS(url) {
var elem = document.createElement("link");
elem.rel = "stylesheet";
elem.type = "text/css";
elem.href = url;
document.body.appendChild(elem);
}
// Download a script dynamically.
function downloadJS(url) {
var elem = document.createElement("script");
elem.src = url;
document.body.appendChild(elem);
}
</script>
我想知道的是:
是否可以重写这两个函数,它们的功能与 downloadCSS(url)
和 downloadJS(url)
基本相同,__without__ 实际上被应用于包含的网页?
实际上,我正在寻找作为下一个网页的外部 CSS/JS 预加载的 downloadCSS(url)
/downloadJS(url)
函数文件,这将表现很像 HTML5 规范打算实现 @prefetch
属性的方式)。我基本上希望通过 post-onload 下载的文件在缓存中准备就绪。
如果没有,关于如何执行相同任务的任何其他建议都会很棒!
提前致谢!
最佳答案
如果你使用 ?t=1388138263
你根本不能预加载,因为每次你都会加载一个新版本..
使用 jquery 你可以做这样的事情:
$.ajax('script.js',{cache: true, dataType:'script'});
//or
$.getScript('script.js')
$.ajax('styles.css',{cache: true});
或者您可以创建不可见的 iframe 并加载到其中加载所有 js 和 css 文件的 html 页面
希望对你有帮助
关于javascript - JavaScript 可以用来预取外部 CSS 和 JS 文件,为同一网站的下一页做好准备吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20799681/
我一直在试图找出为什么这会给我一个错误: PREPARE test FROM 'SELECT t.blah FROM (SELECT ? AS blah) t;'; ERROR 1054 (42S22
我想了解 Go 中的 channel 。我读过默认情况下发送和接收 block ,直到发送方和接收方都准备好。但是我们如何确定发送方和接收方的准备情况。 例如在下面的代码中 package main
大部分的pytorch入门教程,都是使用torchvision里面的数据进行训练和测试。如果我们是自己的图片数据,又该怎么做呢? 1、我的数据 我在学习的时候,使用的是fashion-mnis
在我的 Storyboard中,controller1 有 natigationController 和 segues 到 controller 2。奇怪的是 Segue 工作正常但是 overrid
我正在尝试使用Openshift在线从我的仓库中放入一些代码。 我的构建编译正常,但是部署失败: error: update acceptor rejected nodejs-mongo-persis
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,
我有一个每晚运行的存储过程。 它从链接服务器中提取一些数据并将其插入到运行 sql 代理作业的服务器上的表中。在运行 INSERT 语句之前,该过程检查链接服务器上的数据库是否联机 (STATE =
我对 PDO 准备好的语句比较陌生。 我忍不住觉得必须有一种更简单、更整洁的方法来执行以下操作:我无论如何都将所有内容加载到一个数组中,然后必须将整个内容重写为一组 ':blah '=>$found[
我正在准备一个 pandas 数据框,用于在 R 的 ggplot2 中绘制带有误差条的图,这需要计算列的统计数据。误差条需要最小值(平均值 - 标准偏差)和最大值(平均值+标准差)。我使用 grou
我的 prepareForSegue 方法没有将数据传递到目标 View Controller 。 var buttonsDictionary = [Int: UIButton]() func cre
需要帮助来完成这个简单的任务。该 sp 应该提供一个结果集,并将从 MS-Access-Database 报告目的中调用。 表名可变,但以数字 (lsid) 结尾。使用串联。max_prepared_
我正在为我工作的小型企业创建销售订单表单。我有一个表单连接到数据库以获取下拉菜单,然后连接到文本框以在需要时添加新数据。如果前面的部分中的所有数据框均已填写,还会出现另外四个部分。 链接到数据库的
以下代码: class Database { (...) public function query($query){ $this->stmt = $this->dbh
我正在开展一个学校项目,涉及一个具有数据库集成的网站。目前正致力于通过它向网站添加新内容(文本、标题、图像)。我已经可以通过网站向数据库添加新用户,但由于某种原因,相同的代码和逻辑不适用于内容。 我注
我如何mysqli::stmt->bind_param在mysql中被视为NULL的东西? 我目前正在使用 $stmt->bind_param('s', 'NULL'); 最佳答案 bind_para
我在此处运行准备 stmt 时遇到语法错误。我尝试手动执行 @c 中的查询并且它有效。不知道为什么 stmt 会给出这个错误。这是我正在使用的代码。 SET @i=24; SET @Bill_mont
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我想知道准备好的查询是否与未准备的查询一样安全。下面是两个示例,一个用于 SELECT,一个用于 UPDATE。第一行是未准备的查询,第二行是准备好的查询。 选择示例: $userDetails =
我是 ios 开发的新手,在我尝试做的事情上遇到了障碍。 我的方法中有这段代码,旨在将特定的 NSObject 从这个 View 传递到下一个 View ,但是它总是让我的应用程序崩溃。 -(void
自上次调用 segue 以来,我的 UIButton 类的 statValue 属性已更新,但 segue 仍发送旧的原始值。有没有办法刷新 prepare 函数(如下),以便它发送新值? overr
我是一名优秀的程序员,十分优秀!