Maison interface Web js tutoriel 前端的离线处理

前端的离线处理

Nov 18, 2016 pm 01:28 PM

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

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

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

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

模板的离线处理

自定义标签

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

<el-input-number v-model="num1" @change="handleChange" :min="1" :max="10"></el-input-number>
Copier après la connexion

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

<div class="el-input-number">
    <div class="el-input">
        <input type="text" autocomplete="off" class="el-input__inner">
    </div>
    <span class="el-input-number__decrease el-icon-minus is-disabled"></span>
    <span class="el-input-number__increase el-icon-plus"></span></div>
Copier après la connexion

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.length;i++){%>
    <%=list[i].text%><%}%>
Copier après la connexion

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

<%for(var i=0;i<obj.list.length;i++){%>
    <%=obj.list[i].text%>
<%}%>
Copier après la connexion

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

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

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

var tmpl=&#39;<%=getUser()%>&#39;;
_.template(tmpl,{});
Copier après la connexion

这时可以正常工作

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

var tmpl=&#39;<%=obj.getUser()%>&#39;;
_.template(tmp,{});
Copier après la connexion

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

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

css图片的处理

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

|____index.html
|____index.css
|____index.js
Copier après la connexion

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

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

var Magix=require(&#39;magix&#39;);
var indexHTML=&#39;<div class="mp-et5-content">...</div>&#39;;
Magix.applyStyle(&#39;mp-ec5&#39;,&#39;.mp-et5-content{color:red}&#39;);
Copier après la connexion

更多信息可参考 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)}
Copier après la connexion

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

var Magix=require(&#39;magix&#39;);
var ataptImg=function(img){
  //处理webp 2倍图等
  return img
}
Magix.applyStyle(&#39;mp-ec5&#39;,&#39;.mp-et5-title{background-image:url(&#39;+adaptImg(&#39;//cdn/a.png&#39;)+&#39;}&#39;);
Copier après la connexion

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

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Apr 04, 2025 pm 02:42 PM

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

Qui est payé plus de python ou de javascript? Qui est payé plus de python ou de javascript? Apr 04, 2025 am 12:09 AM

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

Démystifier javascript: ce qu'il fait et pourquoi c'est important Démystifier javascript: ce qu'il fait et pourquoi c'est important Apr 09, 2025 am 12:07 AM

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Apr 04, 2025 pm 05:09 PM

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

Comment réaliser des effets de défilement de parallaxe et d'animation des éléments, comme le site officiel de Shiseido?
ou:
Comment pouvons-nous réaliser l'effet d'animation accompagné d'un défilement de page comme le site officiel de Shiseido? Comment réaliser des effets de défilement de parallaxe et d'animation des éléments, comme le site officiel de Shiseido? ou: Comment pouvons-nous réaliser l'effet d'animation accompagné d'un défilement de page comme le site officiel de Shiseido? Apr 04, 2025 pm 05:36 PM

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? Apr 04, 2025 pm 05:12 PM

Discussion approfondie des causes profondes de la différence de sortie Console.log. Cet article analysera les différences dans les résultats de sortie de la fonction Console.log dans un morceau de code et expliquera les raisons derrière. � ...

JavaScript est-il difficile à apprendre? JavaScript est-il difficile à apprendre? Apr 03, 2025 am 12:20 AM

Apprendre JavaScript n'est pas difficile, mais c'est difficile. 1) Comprendre les concepts de base tels que les variables, les types de données, les fonctions, etc. 2) Master la programmation asynchrone et les implémenter via des boucles d'événements. 3) Utilisez les opérations DOM et promettez de gérer les demandes asynchrones. 4) Évitez les erreurs courantes et utilisez des techniques de débogage. 5) Optimiser les performances et suivre les meilleures pratiques.

Comment implémenter la fonction de glisser-déposer et de régler la fonction de réglage similaire à VScode dans le développement frontal? Comment implémenter la fonction de glisser-déposer et de régler la fonction de réglage similaire à VScode dans le développement frontal? Apr 04, 2025 pm 02:06 PM

Explorez la mise en œuvre de la fonction de glisser et de réglage du panneau de type VScode dans le frontal. Dans le développement frontal, comment implémenter un VScode comme ...

See all articles