Summarize the common properties of BigIn functions in JavaScript

Summarize the common properties of BigIn functions in JavaScript

1. Overview

BigInt is a special numeric type that provides support for integers of arbitrary length.

There are two ways to create bigint : add n after an integer literal or call the BigInt function, which generates bigint from a string, number, etc.

const bigint = 1234567890123456789012345678901234567890n; 
const sameBigint = BigInt("1234567890123456789012345678901234567890"); 
const bigintFromNumber = BigInt(10); // Same as 10n

2. Attributes

1. Mathematical operators

BigInt can be used like regular numeric types in most cases.

For example:

alert(1n + 2n); // 3 
alert(5n / 2n); // 2 

Note: The result of the division 5/2 is rounded towards zero, and the result obtained after rounding has no decimal part. All operations on bigint return results that are also bigint.

You cannot mix bigint and regular numeric types:

alert(1n + 2); // Error: Cannot mix BigInt and other types 

If necessary, you should convert them explicitly: using BigInt() or Number(), like this:

let bigint = 1n; 
let number = 2; 
// Convert number to bigint 
alert(bigint + BigInt(number)); // 3 
// Convert bigint to number 
alert(Number(bigint) + number); // 3 

The conversion is always silent and never raises an error, but if the bigint is too large to fit in the numeric type, the extra bits will be truncated, so such conversions should be done with caution.

BigInt does not support unary addition

The unary addition operator +value is a well-known method for converting value to a numeric type.

To avoid confusion, unary addition is not supported in bigint :

let bigint = 1n; 
alert( +bigint ); // error 

Number() should be used to convert a bigint to a number type.

2. Comparison Operators

Comparison operators, such as < and >, have no problem using them to compare bigint and number types.

alert( 2n > 1n ); // true 
alert( 2n > 1 ); // true 

Note: Because number and bigint are different types, they may be equal when compared with ==, but not equal when compared with === (strict equality):

alert( 1 == 1n ); // true 
 
alert( 1 === 1n ); // false 

3. Boolean operations

When inside an if or other Boolean operation, bigint behaves like number.

Example: In if, bigint 0n is false, and other values ​​are true:

if (0n) {   
  // will never be executed} 


Boolean operators

For example , ||, && and other operators handle bigint in a similar way to number:

alert( 1n || 2 ); // 1 (1n is considered true) 
alert( 0n || 2 ); // 2 (0n is considered false) 

Note: This method recommends using JSBI instead of native bigint when writing code. But JSBI uses number internally like bigint and emulates it as closely as possible to the specification, so the code is already bigint -ready.

For engines that don't support bigint , such JSBI code can be used "as is", for those that do — the polyfill will convert the calls to native bigint.

Conclusion

Based on JavaScript basics, this article introduces BigInt functions, common properties, and comparison of numeric operators through BigInt functions. Boolean operations, etc., are explained in detail through case analysis.

This concludes this article on summarizing the common properties of the BigIn function in JavaScript. For more information about the common properties of the BigIn function in JavaScript, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of BigInt for digital calculations beyond JavaScript safe integer limits

<<:  Use non-root users to execute script operations in docker containers

>>:  Implementation of form submission in html

Recommend

JavaScript Array Detailed Summary

Table of contents 1. Array Induction 1. Split a s...

How to convert a column of comma-separated values ​​into columns in MySQL

Preface Sometimes you come across business tables...

Solve the problem of running hello-world after docker installation

Installed Docker V1.13.1 on centos7.3 using yum B...

How to get the real path of the current script in Linux

1. Get the real path of the current script: #!/bi...

How to disable ads in the terminal welcome message in Ubuntu Server

If you are using the latest Ubuntu Server version...

Installation process of zabbix-agent on Kylin V10

1. Download the installation package Download add...

Interviewer asked how to achieve a fixed aspect ratio in CSS

You may not have had any relevant needs for this ...

Vue complete code to implement single sign-on control

Here is a Vue single sign-on demo for your refere...

Solution to forgetting the MYSQL database password under MAC

Quick solution for forgetting MYSQL database pass...

Preventing SQL injection in web projects

Table of contents 1. Introduction to SQL Injectio...

SystemC environment configuration method under Linux system

The following is the configuration method under c...

HTML table markup tutorial (48): CSS modified table

<br />Now let's take a look at how to cl...

How to find out uncommitted transaction information in MySQL

A while ago, I wrote a blog post titled "Can...