Atitit.减少http请求数方案
Atitit.减少http请求数方案
1. 原理与方法
界面调用js.jsp css.js, 如果存在缓存文件就返回缓存文件,否则
读取js css列表文件
读取文件,拼接成一个大的js css文件,然后缓存起来
作者:: ★(attilax)>>> 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://www.cnblogs.com/attilax/
1.1. -------jsp
<%@ page language="java" import="java.util.*,com.csmy.my.center.util.CTUtils" pageEncoding="UTF-8"%>
<%@ page import="com.attilax.util.connReduceDync"%>
<%@ page import="com.attilax.io.pathx"%>
<%
connReduceDync c=new connReduceDync();
//c.res="com.attilax,core/import.js,core/core.js,core/yaml.js|com.atilax.frmwk,/jquery-1.8.3.min.js ";
c.resfile="index/js.txt";
c.resfileUse=true;
//c.base = "" //def is approot
c.output="index/jobus_index.js"; //index/jobus.js
c.recreateMode=true; //else use append mode
//System.out.println(c.joinNout()); //trest mode
//System.out.println();/
// return;
%>
<%=c.readCacheOrjoinNout()%>
1.2. "index/js.txt";
index/img.js
com.atilax.frmwk/jquery-1.8.3.min.js
com.attilax/HRE.js
com.attilax/jsbridge/jsb_v8q414.js
com.attilax/templete/jquery.tmpl.js
com.atilax.frmwk/unslider.min.js
com.attilax/core/coreV3.js
cmsPhone4jobusImp/list.js
com.attilax/log/logV2.js
1.3. connReduceDync
package com.attilax.util;
import java.io.File;
import java.util.List;
import java.util.Map;
import com.attilax.coll.ListX;
import com.attilax.collection.listUtil;
import com.attilax.io.filex;
import com.attilax.io.pathx;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
/**
* servlet
* @author Administrator
*
* com.attilax.util.connReduceDync
*
*/
public class connReduceDync extends ConnReducerV2 {
public String resfile;
public boolean resfileUse=false;
public static void main(String[] args) {
connReduceDync c=new connReduceDync();
c.res="com.attilax,core/import.js,core/core.js,core/yaml.js|com.atilax.frmwk,/jquery-1.8.3.min.js ";
c.resfile="list/list_jss.txt";
c.resfileUse=true;
//c.base = pathx.webAppPath();
c.output="list/jobus_list.js"; //index/jobus.js
//c.output_css=c.base+"/list/jobus_list.css";
//c.isGeneCss=false;
c.recreateMode=true; //else use append mode
c.genefile=true;
System.out.println(c.joinNout()); //trest mode
//System.out.println(c.readCacheOrjoinNout());//product mode
//Map m=Maps.newLinkedHashMap();
//m.put("res",s);
System.out.println("--f");
}
public String readCacheOrjoinNout() {
output=pathx.fillFullpath(output);
if(new File(this.output).exists())
return filex.read(this.output);
return joinNout();
}
public String joinNout() {
output=pathx.fillFullpath(output);
gene() ;
return this.resCache;
}
private void gene() {
resfile=pathx.webAppPath()+"/"+resfile;
List<String> li=Lists.newLinkedList();
if(resfileUse==false)
li=parseLi(base);
if(resfileUse)
li=listUtil.trimLine( filex.read2list(this.resfile) );
for (String line : li) {
line = line.trim();
if (line.length() == 0)
continue;
importx(line);
}
reduce();
}
private List<String> parseLi(String base) {
List<String> li=Lists.newArrayList();
String reses=res;
String[] rows=reses.split("\\|");
for (String row : rows) {
String[] cols=CsvUtil.toCols(row);
String dir=cols[0];
for (int i=1;i<cols.length;i++) {
String f = cols[i].trim();
if(f.trim().startsWith("/"))
f=f.substring(1);
String full_file=dir+"/"+f;
li.add(full_file);
}
}
return li;
}
}
----------finis
Atitit.减少http请求数方案的更多相关文章
- 页面优化——减少HTTP请求数
1.关于减少http请求数 关于减少http请求数,是前端开发性能优化的一个非常重要方面,所以在基本所有的优化原则里,都有这一条原则:减少http请求数. 先不考虑其他的,我们先考虑为什么减少http ...
- web性能优化--减少客户端请求数(一)
多图标合并,用css分隔 设置较长时间的过期时间 合并多个css文件 合并多个js文件 根据域名划分内容 首先介绍一款速度测试工具:webpagetest(填上url,username,passwor ...
- 高性能WEB开发 为什么要减少请求数,如何减少请求数!
http请求头的数据量 [声明] 转载 原文出处:http://www.blogjava.net/BearRui/. 谢谢我们先分析下请求头,看看每次请求都带了那些额外的数据.下面是监控的googl ...
- 减少HTTP请求之将图片转成二进制并生成Base64编码,可以在网页中通过url查看图片(大型网站优化技术)
在网站开发过程中,对于页面的加载效率一般都想尽办法求快.那么,怎么让才能更快呢?减少页面请求 是一个优化页面加载速度很好的方法.上一篇博文我们讲解了 “利用将小图标合成一张背景图来减少HTTP请求”, ...
- 减少HTTP请求之合并图片详解(大型网站优化技术)
原文:减少HTTP请求之合并图片详解(大型网站优化技术) 一.相关知识讲解 看过雅虎的前端优化35条建议,都知道优化前端是有多么重要.页面的加载速度直接影响到用户的体验.80%的终端用户响应时间都花在 ...
- 高并发大流量专题---3、前端优化(减少HTTP请求次数)
高并发大流量专题---3.前端优化(减少HTTP请求次数) 一.总结 一句话总结: 图片地图:使用<map><area></area></map>标签. ...
- 减少图片HTTP 请求的方案
<Higb Performance Web Sites>(中文名:“高性能网站建设指南”)这本书对于前端工程师来说,绝对值得一读.本人有幸从公司借阅了,但不幸的是感觉翻译有点怪怪的.尤其是 ...
- 前端性能优化 —— 减少HTTP请求
简要:对于影响页面呈选 的因素有3个地方:服务器连接数据库并计算返回数据 , http请求以及数据(文件)经过网络传输 , 文件在浏览器中计算渲染呈选: 其中大约80%的时间都耗在了http请求上,所 ...
- 使用CSS sprites减少HTTP请求
sprites是鬼怪,小妖精,调皮鬼的意思,初听这个高端洋气的名字我被震慑住了,一步步掀开其面纱后发觉很简单的东西,作用却很大 神马是CSS 小妖精 CSS sprites是指把网页中很多小图片(很多 ...
随机推荐
- 一个简单的MVC模式练习
控制层Action接受从模型层DAO传来的数据,显现在视图层上. package Action; import java.sql.Connection; import java.sql.SQLExce ...
- winform 中设置窗体的默认焦点
转载:http://www.cnblogs.com/weekzero/p/3504513.html winform的窗体中,有时候需要设置默认焦点,有时候需要取消默认焦点. 设置默认焦点,最简单的方法 ...
- Vue实例详解与生命周期
http://www.jianshu.com/p/b5858f1e6e76 Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己 ...
- python接口自动化21-规范的API接口文档示例
前言 接口文档到底长啥样?做接口测试最大的障碍在于没有接口文档,很多公司不注重接口文档的编写,导致测试小伙伴没见过接口文档. 运气好一点的测试小伙伴可能厚着脸皮找开发要过接口文档,然而拿过来的接口文档 ...
- jQuery中,子页面与父页面之间的调用方法
在jQuery中, 子页面查找父页面的元素 parent.$("#元素Id") 父页面调用子页面的元素 $("#子页面iframe的Id").contents( ...
- all-oone-data-structure(好)
哈哈,我用了HashMap, 双向链表,还有了HashSet来保存key的集合. 现在这道题目还只有 9.3%的AC率,难度为HardTotal Accepted: 9 Total Submissio ...
- PHP100精华:很靠谱linux常用命令
vim是打开vim编辑器,别的编辑器还有vi(功能没有vim 强大),nano,emacs等等,感觉还是vim最强大,其次是vi,别的就要差一些了. 我听我们老师说,用图形界面本身已经会被高手笑了,如 ...
- UIBarButtonSystemItem
typedefenum { UIBarButtonSystemItemDone, UIBarButtonSystemItemCancel, UIBarButtonSystemItemEdit, UIB ...
- 帮助更语义化的显示时间的jQuery插件 - tidyTime.js
来源:GBin1.com 网站或者web应用开发过程中,难免会遇到需要展示时间的地方,例如,留言时间或者发布帖子的时候,那么大家是不是相关过使用更加符合语义学的方式来显示时间呢? 08:15 显示成 ...
- Discuz常见小问题2-如何在数据库搜索指定关键字
点击搜索,然后输入关键字,注意要全选或者部分选择表(一个数据库的表),点击右下角的执行 会提示有多少个匹配,可以在浏览器中直接搜索"1个匹配"来定位到哪个数据表找到了匹配项,然 ...