Series Overview
In the era of the rise of mobile web, speed optimization has been paid attention to by everyone again, because the network environment and performance of mobile phones are much worse than that of PCs. I guess everyone can also feel that when opening web pages on mobile phones, it can be clearly felt. to the page at a snail's pace.
The optimization of this series will be based on the mobile environment. Of course, most of the rules are also suitable for PC.
Basic principles of optimization
There are some basic ideas for speed optimization, summarize them in advance
On-demand loading (only load what you need)
Parallel (make serial things parallel)
Compression (reduce the size through compression) )
Cache (use cache to reduce request waiting)
Prediction (predict user behavior and issue requests in advance)
Merge (merge multiple scattered files to reduce requests)
Automation (make speed optimization a Conventional, combine with automated tools (such as gulp, grunt, fis) to reduce costs)
Get to the point, optimize your css
Why is the first article talking about css, because css is the most difficult to optimize, you can do both pictures and js Lazy loading, but CSS cannot, you must load css in front of dom, and you must accept the reality that css blocks dom rendering.
css optimization compression (cssshrink)
We generally perform regular compression on css, mainly to remove spaces and line breaks. The cssshrink recommended here will do more detailed work. cssshrink will first parse the css through the css parser, and then perform targeted optimization. For example, Huiba converts 0px and 0% to 0, bold to 700, and the ultimate compression at the character level. Thumbs up for the author.
Cssshrink specific optimization strategy, click here to view
cssshrink: GitHub address
css optimization merge
Use gulp-concat to merge multiple css together
Do not use @import to reduce blocking and requests
css disassembly The points
seem to conflict with the above. This is also the difference between css and other parts of optimization. Generally, we are used to putting css at the top and js at the bottom. This is a good practice, but not the best choice for css.
On the mobile side, everyone attaches great importance to the first screen time, which is the time when users see the page. Put the CSS of the entire page at the top. A large amount of CSS that is not used on the first screen will block the display of the first screen.
The head only puts the css that can be used on the first screen, and the css outside the first screen is moved down
css usage rate
Generally, after multiple people maintain the page, a large amount of unused css will be generated, and no one dares to delete it at will. This requires some detection tools
unu
1.1 unu is a Node.js module used to detect which css on the page are not used
1.2 Advantages: Provides a visual interface, very simple to use, enter the URL to view the usage of the css on the page
1.3 Disadvantages: Currently only Supports style tag css, and does not execute js on the page
uncss
2.1 uncss is a module that can remove unused css from the page
2.2 Advantages: supports command line and gulp, grunt plug-ins, supports link method, based on phantomjs, Simulates browser execution and supports js execution
2.3 Disadvantages: CSS exported by only one URL has no practical value, and it does not support style tags
critical
3.1 critical is used to detect unused css on the first screen Module
3.2 Advantages: You can enter the width and height of the first screen for detection, and there are gulp and grunt plug-ins
3.3 Disadvantages: It does not support url, only supports local html, and does not support style tags
Summary
Speed optimization is a must for developers Things that reduce productivity need to be automated as much as possible, set up rules, and optimize painlessly while avoiding subsequent deterioration.

在css中,可用list-style-type属性来去掉ul的圆点标记,语法为“ul{list-style-type:none}”;list-style-type属性可设置列表项标记的类型,当值为“none”可不定义标记,也可去除已有标记。

区别是:css是层叠样式表单,是将样式信息与网页内容分离的一种标记语言,主要用来设计网页的样式,还可以对网页各元素进行格式化;xml是可扩展标记语言,是一种数据存储语言,用于使用简单的标记描述数据,将文档分成许多部件并对这些部件加以标识。

在css中,可以利用cursor属性实现鼠标隐藏效果,该属性用于定义鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为none时,就可以实现鼠标隐藏效果,语法为“元素{cursor:none}”。

在css中,rtl是“right-to-left”的缩写,是从右往左的意思,指的是内联内容从右往左依次排布,是direction属性的一个属性值;该属性规定了文本的方向和书写方向,语法为“元素{direction:rtl}”。

在css中,可以利用“font-style”属性设置i元素不是斜体样式,该属性用于指定文本的字体样式,当属性值设置为“normal”时,会显示元素的标准字体样式,语法为“i元素{font-style:normal}”。

转换方法:1、给英文元素添加“text-transform: uppercase;”样式,可将所有的英文字母都变成大写;2、给英文元素添加“text-transform:capitalize;”样式,可将英文文本中每个单词的首字母变为大写。

在css3中,可以用“transform-origin”属性设置rotate的旋转中心点,该属性可更改转换元素的位置,第一个参数设置x轴的旋转位置,第二个参数设置y轴旋转位置,语法为“transform-origin:x轴位置 y轴位置”。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Atom editor mac version download
The most popular open source editor

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft
