11.21 脚本 网页优化

一场景,定制个人离线APP,纯html打造,没后端

「没钱买服务器,手机termux一直开着麻烦」

二 功能,让应用启动更迅速。当然,只是给一点方向上参考。肯定有更好的算法。

三 代码,两个,一个html和一个config.js 配置文件放一些 日记,句子 ,项目说明等等转js常量的东西

静态路由,按需加载+缓存

// ==========================================================

// 静态路由下的"按需加载 + 缓存"方案

// 2025-11-21

// ==========================================================

一、说明


  1. 仅当用户第一次进入三级页时,才去拉取 2_10月脚本.js。

  2. 脚本一旦加载,立即挂到 window._allScripts,后续任何再进入

该页面均直接从 window 上复用,不再读盘、不再下载、不再执行。

  1. 纯静态页面,零后端改动,零其他页面改动。

二、三步落地


Step-1 删除原来的静态标签

把页面里这一行整行删掉:

<script src="2_10月脚本.js"></script>

Step-2 在同一 HTML 的 <script> 里(推荐放底部)写:

(function(){

const key = '2_10月脚本.js';

if(window._allScripts && window._allScripts[key]) return; // 已缓存直接返回

const s = document.createElement('script');

s.src = key;

s.onload = () => {

window._allScripts = window._allScripts || {};

window._allScripts[key] = true; // 标记已加载

};

document.head.appendChild(s);

})();

Step-3 业务脚本紧跟其后即可,无需等待回调(脚本执行顺序由浏览器保证)。

三、一页看改法


改前:

<script src="2_10月脚本.js"></script>

<script> /* 你的业务逻辑 */ </script>

改后:

<script>

(function(){

const key = '2_10月脚本.js';

if(window._allScripts && window._allScripts[key]) return;

const s = document.createElement('script');

s.src = key;

s.onload = () => {

window._allScripts = window._allScripts || {};

window._allScripts[key] = true;

};

document.head.appendChild(s);

})();

/* 你的业务逻辑 */

</script>

四、可选增强:通用缓存工具


window.ScriptCache = {

has: function (url) {

return window._allScripts && window._allScripts[url];

},

get: function (url) {

return this.has(url) ? window._allScripts[url] : null;

},

set: function (url, data) {

window._allScripts = window._allScripts || {};

window._allScripts[url] = data || true;

},

remove: function (url) {

if(window._allScripts) delete window._allScripts[url];

},

clear: function () {

window._allScripts = {};

},

stats: function () {

return Object.keys(window._allScripts || {}).length;

}

};

五、使用示例


if (!window.ScriptCache.has('2_10月脚本.js')) {

const s = document.createElement('script');

s.src = '2_10月脚本.js';

s.onload = () => window.ScriptCache.set('2_10月脚本.js');

document.head.appendChild(s);

}

六、注意事项


  1. 若脚本内部依赖 DOM,请确保加载脚本前 DOM 已就绪(可包在 DOMContentLoaded 里)。

  2. 若存在同名字段冲突,可把 window._allScripts 换成任意全局变量。

  3. 本方案仅适用于纯静态站点,无构建工具、无路由框架场景。

相关推荐
IronMurphy6 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬6 小时前
【AI】Hermes的GEPA算法
人工智能·算法
QQ1__8115175156 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态6 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子6 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室6 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI6 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing6 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者6 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册6 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json