Home >Web Front-end >JS Tutorial >Javascript optimization skills (file slimming)_javascript skills

Javascript optimization skills (file slimming)_javascript skills

WBOY
WBOYOriginal
2016-05-16 19:06:141140browse

Recently I have been studying Javascript related technologies. There is a chapter in "Javascript Advanced Programming" that focuses on the importance of optimizing Javascript code. I believe that there are many Javascript developers who will be more or less exposed to such problems while developing.

In most cases, code optimization is not the part that needs to be focused on in actual development. But once the code is completed, developers always expect their code to be as short and efficient as possible. Combining the knowledge gained from the book and my experience in the actual development process, the following explains some of the tricks I have adopted (it can be regarded as following the script).

Foreword

Compared with scripting languages, compiled languages ​​do not need to worry too much about optimization issues. To a large extent, the compiler will perform optimization operations at compile time. For example, all variables, functions, objects, etc. will be replaced with symbols and pointers that only the processor can understand (usually referred to as executable files). Other scripting languages ​​do not need to worry too much about file size, but Javascript is different.
Because it first downloads the source code from the server side, and then executes it by the client's browser. Therefore, the speed of Javascript code is split into two parts: download time (depending on the size of the file) and execution speed (depending on the code algorithm). This article mainly discusses the optimization of Javascript download time, that is, how to reduce the size of the Javascript file itself as much as possible.
One number to keep in mind here is 1160, which is the number of bytes that can fit into a single TCP/IP packet. Therefore, the best expectation is to keep each Javascript file under 1160 bytes for optimal download time.

Delete comment

This seems like nonsense, but many developers forget it. In an actual production environment, comments in scripts should be removed. Comments are very important during development as they help the team understand the code. However, in an actual production environment, comments will significantly increase the size of the script file. Deleting them will not have any impact on the actual execution of the script.

Remove tabs and spaces

Code with good indentation and whitespace is generally good readability. But browsers don't need these extra tabs and spaces, so it's best to remove them. Of course, don't forget the spaces between function parameters, assignment statements, and comparison operations. for example

function showMeTheMoney(money)
{
if (!money) {
return false;
} else {
 …
}
} can be optimized into

function showMeTheMoney(money){if(!money){reutrn false;}else{...}}

This can reduce some capacity.

Remove all line breaks

There is a lot of thought about the existence of line breaks in Javascript, but the bottom line is that line breaks increase the readability of the code. However, excessive line breaks will also increase the code size.
There may be some reason why the newlines cannot be removed, so make sure the file is in Unix format. Because the newline character in Windows and Mac formats uses two characters to represent a newline; Unix only uses one. So converting the file to Unix format can also save some bytes.

Replace variable name

This is probably the most boring way to do it, and it's not usually done by hand. After all, variable names are meaningless to the interpreter (just more friendly to developers), and replacing descriptive variable names with simpler, shorter names can also reduce some size in a production environment. For example, the above code can be reduced to:

function sm(m){if(!m){reutrn false;}else{...}}

Although this may seem like a headache, the actual effect is the same.

Use tools

There may be some difficulties in actually using the above method. Fortunately, there are ready-made external tools that can complete these steps. Here are a few brief introductions:
ECMAScript Cruncher: http://saltstorm.net/depo/esc/
JSMin (The JavaScript Minifier): http://www.crockford.com/javascript/jsmin.html
Online JavaScript Compressor.: http://dean.edwards.name/packer/

I guess you will be interested in reading this article.

Other methods

Replace Boolean value

For comparison, true is equal to 1 and false is equal to 0. Therefore, the literal true contained in the script can be replaced with 1, and false can be replaced with 0. This saves 3 bytes for true and 4 bytes for false.

Shorten negative detection

There are often statements in the code that test whether a certain value is valid.Most conditional non-judgments are to determine whether a variable is undefined, null or false, for example:

if (myValue != undefined) {
// ...
}

if (myValue != null) {
// ...
}

if (myValue != false) {
// ...
}

Although these are correct, you can also use the logical NOT operator to have the same effect:

if (!myValue) {
// ...
}

Such a replacement can also save some bytes.

Use array and object literals

This is easier to understand. For example, the following two lines are the same:

var myArray = new Array;
var myArray = [];

However, the second line is much shorter than the first line and can be easily understood. Similar is the object declaration:


var myObject = new Object;
var myObject = {};

For example, take the following statement:

var mySite = new Object;
mySite.author = "feelinglucky";
mySite.location = "http://www.gracecode.com";

Writing like this can also be very easy to understand and is much shorter:

var mySite = {author:"feeinglucky", location:"http://www.gracecode.com"};

Okay, that’s it for this issue. As mentioned above, the speed of Javascript code is divided into two parts: download time (depending on the file size) and execution speed (depending on the code algorithm). This time we are discussing the optimization of download time, and we will discuss the optimization of travel speed in the next issue (this seems very technical, doesn’t it).

Homework is assigned below. Maybe you will be interested in knowing how jQuery compresses its 70KB code to about 20KB.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn