In this article, I will share with you 12 tips about JavaScript. These tips may help you solve some problems in your actual work.
Use !!
operator to convert Boolean value
Sometimes we need to check whether a variable exists or check whether the value has a valid value, and return if it exists true
value. In order to do such verification, we can use the !!
operator, which is very convenient and simple. For variables, you can use !!variable
for detection, as long as the value of the variable is: 0
, null
, " "
, undefined
or NaN
will return false
, otherwise true
will be returned. 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
In this example, as long as the value of account.cash
is greater than 0
, then account.hasMoney
returns The value is true
.
Use +
to convert strings into numbers
This technique is very useful and 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
This also applies to Date
, in this case, it will return the time Stamp the number:
console.log(+new Date()) // 1461288164385
and conditional character
If you have a piece of code like this:
if (conected) { login(); }
You can also abbreviate the variable and use &&
Connected with functions, such as the above example, it can be abbreviated as follows:
conected && 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();
Use ||
operator
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 argument. If the value returned by the first parameter is false
, then the second value will be considered a default value. Such as 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
Cache in the looparray.length
This technique is very simple. This has 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]); }
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 array size 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]); }
You can also write it like this:
for(var i = 0, length = array.length; i < length; i++) { console.log(array[i]); }
Detect the attributes in the object
This little trick is useful when you need to detect the existence of some properties and 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 IE6 browser, but this function does not exist in IE6 browser, then It is very useful to use this operator to detect whether the function exists, as in the following example:
if ('querySelector' in document) { document.querySelector("#id"); } else { document.getElementById("id"); }
In this example, if document
does not existquerySelector
function, then docuemnt.getElementById("id")
will be called.
Get the last element in the array
Array.prototype.slice(begin,end)
is used to get begin
and end# Array elements between ##. 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]Array truncationThis little trick 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. Such as 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]Replace all
String.replace() function allows you to use strings or regular expressions to replace strings. This function itself only Replace the first occurrence of the string, but you can use
/g in regular expressions to simulate the
replaceAll() function:
var string = "john john"; console.log(string.replace(/hn/, "ana")); // "joana john" console.log(string.replace(/hn/g, "ana")); // "joana joana"Merge arraysIf you want to merge two arrays, generally you will use the
Array.concat() function:
var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.concat(array2)); // [1,2,3,4,5,6];Then this function is not suitable for merging two arrays. Large arrays because it will consume a lot of memory to store the newly created array. In this case, you can use
Array.pus().apply(arr1,arr2) instead of creating a new array. This method is not used to create a new array, it just merges the first and second arrays together while reducing memory usage:
var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];
将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
数组元素的洗牌
对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:
var list = [1,2,3]; console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]
总结
现在你学会了些有用的JavaScript小技巧。希望这些小技巧能在工作中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。如果你有一些优秀的JavaScript小技巧,欢迎在评论中与我们一起分享。
以上就是关于12个非常实用的JavaScript小技巧的代码实例详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!

JavaScript originated in 1995 and was created by Brandon Ike, and realized the language into C. 1.C language provides high performance and system-level programming capabilities for JavaScript. 2. JavaScript's memory management and performance optimization rely on C language. 3. The cross-platform feature of C language helps JavaScript run efficiently on different operating systems.

JavaScript runs in browsers and Node.js environments and relies on the JavaScript engine to parse and execute code. 1) Generate abstract syntax tree (AST) in the parsing stage; 2) convert AST into bytecode or machine code in the compilation stage; 3) execute the compiled code in the execution stage.

The future trends of Python and JavaScript include: 1. Python will consolidate its position in the fields of scientific computing and AI, 2. JavaScript will promote the development of web technology, 3. Cross-platform development will become a hot topic, and 4. Performance optimization will be the focus. Both will continue to expand application scenarios in their respective fields and make more breakthroughs in performance.

Both Python and JavaScript's choices in development environments are important. 1) Python's development environment includes PyCharm, JupyterNotebook and Anaconda, which are suitable for data science and rapid prototyping. 2) The development environment of JavaScript includes Node.js, VSCode and Webpack, which are suitable for front-end and back-end development. Choosing the right tools according to project needs can improve development efficiency and project success rate.

Yes, the engine core of JavaScript is written in C. 1) The C language provides efficient performance and underlying control, which is suitable for the development of JavaScript engine. 2) Taking the V8 engine as an example, its core is written in C, combining the efficiency and object-oriented characteristics of C. 3) The working principle of the JavaScript engine includes parsing, compiling and execution, and the C language plays a key role in these processes.

JavaScript is at the heart of modern websites because it enhances the interactivity and dynamicity of web pages. 1) It allows to change content without refreshing the page, 2) manipulate web pages through DOMAPI, 3) support complex interactive effects such as animation and drag-and-drop, 4) optimize performance and best practices to improve user experience.

C and JavaScript achieve interoperability through WebAssembly. 1) C code is compiled into WebAssembly module and introduced into JavaScript environment to enhance computing power. 2) In game development, C handles physics engines and graphics rendering, and JavaScript is responsible for game logic and user interface.

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.


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

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

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Dreamweaver Mac version
Visual web development tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

Dreamweaver CS6
Visual web development tools
