Home Web Front-end JS Tutorial Some tips for JavaScript

Some tips for JavaScript

Jan 16, 2017 pm 01:40 PM

This article mainly introduces the relevant information collected by JavaScript tips. Friends who need it can refer to it. I hope to provide you with these short and practical JavaScript tips to improve your programming ability.

Use the !! operator to convert a Boolean value

Sometimes we need to check whether a variable exists or check whether the value has a valid value, and return it if it exists true value. In order to do such verification, we can use the !! operator, which is very convenient and simple. You can use !!variable to detect variables. As long as the value of the variable is: 0, null, " ", undefined or NaN, it will return false, otherwise it will return true. For example, the following example:

function Account(cash) {
    this.cash = cash;
    this.hasMoney = !!cash;
}
var account = new Account(100.50);
console.log(account.cash); // 100.50
console.log(account.hasMoney); // true
var emptyAccount = new Account(0);
console.log(emptyAccount.cash); // 0
console.log(emptyAccount.hasMoney); // false
Copy after login

In this example, as long as the value of account.cash is greater than 0, the value returned by account.hasMoney is true.

Use + to convert strings into numbers

This technique is very useful, it is very simple, it can convert string data into numbers, but it is only suitable for String data, otherwise NaN will be returned, such as the following example:

function toNumber(strNumber) {
    return +strNumber;
}
console.log(toNumber("1234")); // 1234
console.log(toNumber("ACB")); // NaN
Copy after login

This also applies to Date, in this case, it will return the timestamp number:

console.log(+new Date()) // 1461288164385
Copy after login

And conditional character

If you have a piece of code like this:

if (conected) {
    login();
}
Copy after login

You can also abbreviate variables and use && to connect them with functions, such as the above example, you can The abbreviation is like this:

conected && login();
Copy after login

If some properties or functions exist in an object, you can also do this detection, as shown in the following code:

user && user.login();
Copy after login

Use || operation The symbol

has the feature of default parameters in ES6. To emulate this feature in older browsers, use the || operator and pass the default value as the second parameter. If the first parameter returns false, the second value will be considered a default value. Take the following example:

function User(name, age) {
    this.name = name || "Oliver Queen";
    this.age = age || 27;
}
var user1 = new User();
console.log(user1.name); // Oliver Queen
console.log(user1.age); // 27
var user2 = new User("Barry Allen", 25);
console.log(user2.name); // Barry Allen
console.log(user2.age); // 25
Copy after login

Cache array.length in a loop

This technique is very simple. This will have an impact on performance when processing a large array loop. will be very big. Basically, everyone will write an array that iterates synchronously like this:

for(var i = 0; i < array.length; i++) {
    console.log(array[i]);
}
Copy after login

If it is a small array, this is fine. If you are dealing with a large array, this code will iterate on each iteration. The size of the array will all be recalculated, which will cause some delays. In order to avoid this phenomenon, you can make a cache of array.length:

var length = array.length;
for(var i = 0; i < length; i++) {
    console.log(array[i]);
}
Copy after login

You can also write it like this:

for(var i = 0, length = array.length; i < length; i++) {
    console.log(array[i]);
}
Copy after login

Detect the attributes in the object

When you need This little trick is useful when checking the existence of some properties to avoid running undefined functions or properties. You might also want to use this trick if you plan to customize some cross-browser code. For example, you want to use document.querySelector() to select an id and make it compatible with the IE6 browser, but this function does not exist in the IE6 browser, so it is difficult to use this operator to detect whether the function exists. Very useful, as in the following example:

if (&#39;querySelector&#39; in document) {
    document.querySelector("#id");
} else {
    document.getElementById("id");
}
Copy after login

In this example, if the querySelector function does not exist in the document, then docuemnt.getElementById("id") will be called.

Get the last element in the array

Array.prototype.slice(begin,end) is used to get the array elements between begin and end. If you do not set the end parameter, the default length value of the array will be used as the end value. But some students may not know that this function can also accept negative values ​​as parameters. If you set a negative value as the value of begin, then you can get the last element of the array. For example:

var array = [1,2,3,4,5,6];
console.log(array.slice(-1)); // [6]
console.log(array.slice(-2)); // [5,6]
console.log(array.slice(-3)); // [4,5,6]
Copy after login

Array truncation

This tip is mainly used to lock the size of the array. It is very useful if it is used to delete some elements in the array. . For example, your array has 10 elements, but you only want the first five elements, then you can truncate the array by array.length=5. As in the following example:

var array = [1,2,3,4,5,6];
console.log(array.length); // 6
array.length = 3;
console.log(array.length); // 3
console.log(array); // [1,2,3]
Copy after login

replaces all

String.replace()函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的/g来模拟replaceAll()函数功能:

var string = "john john";
console.log(string.replace(/hn/, "ana")); // "joana john"
console.log(string.replace(/hn/g, "ana")); // "joana joana"
Copy after login

合并数组

如果你要合并两个数组,一般情况之下你都会使用Array.concat()函数:

var array1 = [1,2,3];
var array2 = [4,5,6];
console.log(array1.concat(array2)); // [1,2,3,4,5,6];
Copy after login

然后这个函数并不适合用来合并两个大型的数组,因为其将消耗大量的内存来存储新创建的数组。在这种情况之个,可以使用Array.pus().apply(arr1,arr2)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:

var array1 = [1,2,3];
var array2 = [4,5,6];
console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];
Copy after login

将NodeList转换成数组

如果你运行document.querySelectorAll(“p”)函数时,它可能返回DOM元素的数组,也就是NodeList对象。但这个对象不具有数组的函数功能,比如sort()、reduce()、map()、filter()等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用[].slice.call(elements)来实现:

var elements = document.querySelectorAll("p"); // NodeList
var arrayElements = [].slice.call(elements); // Now the NodeList is an array
var arrayElements = Array.from(elements); // This is another way of converting NodeList to Array
Copy after login

数组元素的洗牌

对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:

var list = [1,2,3];
console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]
Copy after login

转换数值的更加的方法

将字符串转换为数字是非常常见的。最简单和最快的(jspref)的方式来实现,将使用+(加)算法。

var one = &#39;1&#39;;
var numberOne = +one; // Number 1
Copy after login

你也可以使用-(减号)算法的转换类型并且变成负数值。

var one = &#39;1&#39;;
var negativeNumberOne = -one; // Number -1
Copy after login

返回对象的函数能够用于链式操作

当创建面向对象的JavaScript对象的function时,函数返回一个对象将能够让函数可链式的写在一起来执行。

function Person(name) {
this.name = name;
this.sayName = function() {
console.log("Hello my name is: ", this.name);
return this;
};
this.changeName = function(name) {
this.name = name;
return this;
};
}
var person = new Person("John");
person.sayName().changeName("Timmy").sayName();
//Hello my name is: John
//Hello my name is: Timmy
Copy after login

给回调函数传递参数

在默认情况下,你无法将参数传给回调函数,如下:

function callback() {
console.log(&#39;Hi human&#39;);
}
document.getElementById(&#39;someelem&#39;).addEventListener(&#39;click&#39;, callback);
Copy after login

你可以采取JavaScript闭包的优点来给回调函数传参,案例如下:

function callback(a, b) {
return function() {
console.log(&#39;sum = &#39;, (a+b));
}
}
var x = 1, y = 2;
document.getElementById(&#39;someelem&#39;).addEventListener(&#39;click&#39;, callback(x, y));
Copy after login

什么是闭包呢?闭包是指一个针对独立的(自由)变量的函数。换句话说,闭包中定义的函数会记住它被创建的环境。了解更多请参阅MDN所以这种方式当被调用的时候,参数X/Y存在于回调函数的作用域内。

另一种方法是使用绑定方法。例如:

var alertText = function(text) {
alert(text);
};
document.getElementById(&#39;someelem&#39;).addEventListener(&#39;click&#39;, alertText.bind(this, &#39;hello&#39;));
Copy after login

提升

理解提升将帮助你组织你的function。只需要记住,变量声明和定义函数会被提升到顶部。变量的定义是不会的,即使你在同一行中声明和定义一个变量。此外,变量声明让系统知道变量存在,而定义是将其赋值给它。

function doTheThing() {
// 错误: notDeclared is not defined
console.log(notDeclared);
// 输出: undefined
console.log(definedLater);
var definedLater;
definedLater = &#39;I am defined!&#39;
// 输出: &#39;I am defined!&#39;
console.log(definedLater)
// Outputs: undefined
console.log(definedSimulateneously);
var definedSimulateneously = &#39;I am defined!&#39;
// 输出: &#39;I am defined!&#39;
console.log(definedSimulateneously)
// 输出: &#39;I did it!&#39;
doSomethingElse();
function doSomethingElse(){
console.log(&#39;I did it!&#39;);
}
// 错误: undefined is not a function
functionVar();
var functionVar = function(){
console.log(&#39;I did it!&#39;);
}
}
Copy after login

为了使事情更容易阅读,在函数作用域内提升变量的声明将会让你明确该变量的声明是来自哪个作用域。在你需要使用变量之前定义它们。在作用域底部定义函数,确保代码清晰规范。

希望这些小技巧能在工作中帮助你解决一些麻烦,对你有所帮助。

Statement of this Website
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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What should I do if I encounter garbled code printing for front-end thermal paper receipts? What should I do if I encounter garbled code printing for front-end thermal paper receipts? Apr 04, 2025 pm 02:42 PM

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

Demystifying JavaScript: What It Does and Why It Matters Demystifying JavaScript: What It Does and Why It Matters Apr 09, 2025 am 12:07 AM

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

Who gets paid more Python or JavaScript? Who gets paid more Python or JavaScript? Apr 04, 2025 am 12:09 AM

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

How to merge array elements with the same ID into one object using JavaScript? How to merge array elements with the same ID into one object using JavaScript? Apr 04, 2025 pm 05:09 PM

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

Is JavaScript hard to learn? Is JavaScript hard to learn? Apr 03, 2025 am 12:20 AM

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

How to achieve parallax scrolling and element animation effects, like Shiseido's official website?
or:
How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? How to achieve parallax scrolling and element animation effects, like Shiseido's official website? or: How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? Apr 04, 2025 pm 05:36 PM

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

The difference in console.log output result: Why are the two calls different? The difference in console.log output result: Why are the two calls different? Apr 04, 2025 pm 05:12 PM

In-depth discussion of the root causes of the difference in console.log output. This article will analyze the differences in the output results of console.log function in a piece of code and explain the reasons behind it. �...

The Evolution of JavaScript: Current Trends and Future Prospects The Evolution of JavaScript: Current Trends and Future Prospects Apr 10, 2025 am 09:33 AM

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

See all articles