What Is JavaScript Tilde? When And How To Use It?

When building dynamic and interactive web applications, one of the operators to master is JavaScript tilde(~).

In this article, we will delve into the world of tildes in JavaScript and explore how to utilize them effectively in your code.

Whether you are a novice or a skilled developer, this article will offer you valuable insights and examples to enhance your coding proficiency.

What is tilde in JavaScript?

In JavaScript, the tilde (~) symbol is a bitwise NOT operator. It’s used to perform a bitwise negation on the binary representation of a number.

Moreover, when you apply the tilde operator to a number, it flips all the bits of that number, changing 0s to 1s and 1s to 0s.

Here’s an example to illustrate how the tilde operator works:

let num = 42;  // Binary: 101010
let result = ~num;

console.log(result);  // Output: -43

In this example, the binary representation of 42 is 101010. When you apply the bitwise NOT operation to it, you get 010101, which represents the decimal value 21 in two’s complement form.

However, JavaScript represents negative numbers using two’s complement notation, so the result is -43 instead of 21.

How to use tilde in JavaScript

Tildes in JavaScript have multiple applications, ranging from manipulating bitwise operations to working with arrays and strings.

Let’s explore various use cases:

Checking Bitwise NOT

The tilde operator in JavaScript is primarily known for performing a bitwise NOT operation.

It flips the bits of a number, turning each 0 into 1 and each 1 into 0. This can be particularly useful in scenarios where you need to invert certain bit patterns.

let num = 42;
let bitwiseNotResult = ~num;
// Result: -43

Indexing in Arrays

Tildes can also aid in indexing arrays. They can be used to convert a zero-based index to its negative form, indicating the index from the end of the array. This can simplify operations that involve accessing elements from the end.

let fruits = ['apple', 'banana', 'orange'];
let lastIndex = ~-2; // Equivalent to fruits.length - 2
let lastButOneFruit = fruits[lastIndex];
// Result: 'banana'

String Manipulation

Tildes can be employed to manipulate strings as well. By using tildes, you can efficiently reverse the order of characters in a string.

let text = 'Hello, world!';
let reversedText = text.split('').reverse().join('');
// Result: '!dlrow ,olleH'

Dealing with Truthy and Falsy Values

Tildes can help identify falsy values in JavaScript. When applied to a value, the tilde operator converts it to a 32-bit signed integer and then checks if it’s equal to -1. This can be used to determine whether a value is falsy.

function isFalsy(value) {
  return ~value ? false : true;
}

console.log(isFalsy(0));     // true
console.log(isFalsy(''));    // true
console.log(isFalsy(null));  // true
console.log(isFalsy(false)); // true

Bitwise AND with Negative One

Combining the tilde with the bitwise AND operator (&) and -1 can result in a more efficient way to truncate decimal numbers. This is equivalent to using the Math.floor() function.

Example:

let decimalNumber = 7.8; let truncatedNumber = decimalNumber | 0; // Result: 7

Conclusion

To sum up, mastering the usage of the tilde operator in JavaScript can significantly imporoved your coding skills.

By performing bitwise operations to optimize code performance, tildes offer a range of possibilities.

By incorporating tildes into your coding toolkit you can tackle complex problems with more efficient solutions.

Frequently Asked Questions

Is JavaScript still worth learning in 2026?
Yes. JavaScript runs on 98% of websites for the front-end, dominates the back-end via Node.js, powers mobile apps through React Native, builds desktop tools through Electron, and is the scripting layer for most AI tooling (LangChain.js, OpenAI SDK, Vercel AI). Whether you target web, mobile, AI, or full-stack capstones, JavaScript is the broadest single language you can learn.
What is the difference between var, let, and const?
var is function-scoped, hoisted to the top of its scope, and can be redeclared, which leads to bugs in modern code. let is block-scoped (only visible inside the nearest {}) and can be reassigned. const is block-scoped and cannot be reassigned, although object contents can still mutate. Default to const for everything, switch to let only when you actually need to reassign, and avoid var in any code written after 2017.
Which JavaScript version should I target in 2026?
Target ES2020 (ES11) as the safe baseline because every modern browser and Node.js 14+ supports it fully. ES2022 adds useful features like top-level await, private class fields with the # prefix, and the .at() array method. If you are writing for older browsers (IE11 or older Android WebViews), transpile down with Babel or use a build tool like Vite, esbuild, or webpack.
What is the best free editor for JavaScript?
Visual Studio Code is the industry standard, free, with built-in IntelliSense, debugger, terminal, Git, and a huge extension marketplace (ESLint, Prettier, GitHub Copilot, Tailwind). Install the JavaScript and TypeScript Nightly extension for the latest language features. JetBrains WebStorm is more powerful and free for students with a verified .edu email. For quick scratchpad work, the Chrome DevTools Sources panel includes a workspace and breakpoint debugger.
How do I run JavaScript locally vs in the browser?
In the browser: open DevTools with F12 (or right-click then Inspect), go to the Console tab, type or paste your code, press Enter. For HTML pages, add a script tag pointing to your .js file. Locally with Node.js: download Node from nodejs.org (LTS version), then run node script.js in your terminal from the file folder. Use the same Node setup for backend capstones, API integrations, and scripts that do not need a browser.
What can I build with JavaScript for my BSIT capstone?
Common BSIT capstones in JavaScript: full-stack web apps using React or Vue on the front-end with Node.js and Express on the back-end (MongoDB or MySQL for the database), real-time chat or notification systems using Socket.io, single-page dashboards with Chart.js or D3.js, cross-platform mobile apps with React Native, AI-powered chatbots using OpenAI SDK and LangChain.js, and Chrome extensions for productivity tools. Add Tailwind CSS for the UI and Vercel or Netlify for free deployment.
Glay Eliver

Programmer & Technical Writer at PIES IT Solution

Glay Eliver is a programmer and writer at PIES IT Solution, author of over 600 tutorials at itsourcecode.com. Specializes in JavaScript tutorials, Microsoft Office how-tos (Excel, Word, PowerPoint), and Python error debugging covering ImportError, TypeError, AttributeError, ModuleNotFoundError, and JavaScript ReferenceError. Authored several of the site’s highest-traffic Excel and MS Office reference articles.

Expertise: JavaScript · MS Excel · MS Word · MS PowerPoint · Python · Python ImportError · Python TypeError · Python AttributeError · ModuleNotFoundError · JavaScript ReferenceError · Pygame  · View all posts by Glay Eliver →

Leave a Comment