0

0

前端的离线处理

高洛峰

高洛峰

发布时间:2016-11-18 13:28:04

|

1546人浏览过

|

来源于php中文网

原创

这里的离线处理指线下把一些事件提前做好,不在应用运行时再去做

其实前端的离线处理在一些工具中可以看到,比如说css中的背景图,某些css工具在打包处理的时候,如果图片的文件大小比较小,工具会读取文件内容转成base64直接放到css文件内,减少http请求。

类似的还有使用字符串模板的情况下,提前把字符串模板变成js中的函数,避免运行时再去生成相应的函数

接下来聊聊其他的离线处理

模板的离线处理

自定义标签

现在很多前端框架支持自定义标签的书写方式,比如基于vue的element。我们以它的inputnumber为例来看一下: http://element.eleme.io/#/en-US/component/input-number

立即学习前端免费学习笔记(深入)”;

一个自定义的el-input-number标签,最终生成的html是

vue会把自定义标签替换成最终实现的html内容,这个过程是运行时做的。其实这个过程是可以通过工具线下处理好的,不必在程序运行时再做。

字符串模板

字符串模板在很多前端页面中可见,模板引擎也很多,以underscore中的template方法为例:https://github.com/jashkenas/underscore/blob/master/underscore.js#L1579,它里面在生成函数时,如果没有variable参数,则会加一个with语句,通常我们是避免掉with的

那么有没有什么办法是不用传variable,也不使用with语句呢?这个也是可以线下处理好的。比如模板如下

<%for(var i=0;i
    <%=list[i].text%><%}%>

通过工具我们是很容易转换成下面的内容的

<%for(var i=0;i
    <%=obj.list[i].text%>
<%}%>

这个就需要借助acorn类似的工具来处理了,不过肯定是可以做到的。

有的同学说这样做是错的,因为with语句不在运行时,根本不知道它里面的变量从哪里取值。是的,不过我们完全可以通过约定模板中用到的变量都应该在使用时,显式传递

比如window上有一个getUser()方法在去掉with前

var tmpl='<%=getUser()%>';
_.template(tmpl,{});

这时可以正常工作

Pixlr
Pixlr

Pixlr是一款2008年推出的在线图片编辑和AI图片处理工具,目前已推出AI 图像生成器、AI 生成填充、AI 删除背景、AI 删除对象和 AI 图像扩展等现代 AI 工具。

下载

通过离线工具的处理,去掉with后,模板变成了

var tmpl='<%=obj.getUser()%>';
_.template(tmp,{});

这时候就不行了,不过我们可以约定模板中使用到的都应该在调用时显式传递,从而避免一些潜在的问题出现。

当然,这个模板字符串离线处理最好的结果是直接就是一个函数放在那里了。

css图片的处理

在我们的项目中,考虑如下文件结构

|____index.html
|____index.css
|____index.js

我们通常是把html和css打包时,打包到js文件中的,因为js文件可以很方便的模块化,把html,css依附在js文件上。这样js按需加载时,html和css也按需加载了,而且不需要为它们特殊处理。

假设它们最终打包出来index.js如下

var Magix=require('magix');
var indexHTML='
...
'; Magix.applyStyle('mp-ec5','.mp-et5-content{color:red}');

更多信息可参考 https://github.com/thx/magix-combine/issues/15这个打包工具。

样式变成一个字符串放在js文件中。

我们看一个事情:在css中使用背景图时,为了达到最佳实践,我们希望在支持webp后缀的使用webp,在高清屏下使用2倍图等 。如果我们用纯css实现,要写很多media query,产生css代码。

其实这个事情我们没办法离线处理,但我们可以这样做:书写css仍然是写最基础的背景图,不去考虑webp,2倍图等事情,也不需要写media query之类的。在打包时,把图片这块调用js函数在运行时动态处理

如前面文件结构中的,假设index.css中使用了一个背景图

.title{background-image:url(//cdn/a.png)}

我们打包到js中时,完全可以变成

var Magix=require('magix');
var ataptImg=function(img){
  //处理webp 2倍图等
  return img
}
Magix.applyStyle('mp-ec5','.mp-et5-title{background-image:url('+adaptImg('//cdn/a.png')+'}');

这样可以很方便的处理掉这些事情。

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

4

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

3

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

10

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

15

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

7

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号