Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
JavaScript

JavaScript: Use Nullish Coalescing (??) Instead of || for Default Values

- 27.05.26 - ErcanOPAK

?? vs || — The Important Difference

`||` treats 0, ”, false as falsy. `??` only checks `null` and `undefined`. Use ?? for default values.

❌ Logical OR (||) Trap

const count = userInput || 10;
// If userInput = 0 → count = 10 (WRONG!)

const name = userName || 'Guest';
// If userName = '' → name = 'Guest' (WRONG!)

const enabled = isEnabled || true;
// If isEnabled = false → enabled = true (WRONG!)

✅ Nullish Coalescing (??)

const count = userInput ?? 10;
// If userInput = 0 → count = 0 (CORRECT!)
// If userInput = null → count = 10

const name = userName ?? 'Guest';
// If userName = '' → name = '' (CORRECT!)
// If userName = null → name = 'Guest'

const enabled = isEnabled ?? true;
// If isEnabled = false → enabled = false (CORRECT!)
// If isEnabled = null → enabled = true

📝 When to Use Which

// Use ?? when 0, '', false are valid values
const volume = settings.volume ?? 50;  // volume can be 0 (muted)
const name = user.name ?? 'Anonymous'; // name can be empty string
const isAdmin = user.role ?? false;    // role could be empty

// Use || for truthy fallback
const displayName = user.nickname || user.name || 'Guest';
const apiUrl = process.env.API_URL || 'https://default.api.com';

// Combining ?? with &&, ||
const value = (a ?? b) || c;

// Nullish assignment (??=)
let options = {};
options.timeout ??= 3000;  // Only sets if undefined/null
options.retries ??= 3;

✅ Real-World Examples

// API response handling
const pageSize = response.data?.pageSize ?? 20;
const sortOrder = response.data?.sortOrder ?? 'desc';
const filters = response.data?.filters ?? {};

// Form inputs
const age = parseInt(input.value) ?? 0;  // 0 is valid age

// Configuration with defaults
const config = {
  retryCount: userConfig.retryCount ?? 3,
  timeout: userConfig.timeout ?? 5000,
  enableCache: userConfig.enableCache ?? true  // false is valid
};

// Optional chaining + nullish coalescing
const city = user?.address?.city ?? 'Unknown';

💡 Browser Support

  • Chrome 80+ ✅
  • Firefox 72+ ✅
  • Safari 13.1+ ✅
  • Node.js 14+ ✅
  • TypeScript 3.7+ ✅

“Bug: Volume slider defaulted to 50 when user set to 0. Used ||. Fixed with ??. Took 2 hours to find. Never using || for defaults again.”

— Frontend Developer

Related posts:

JavaScript: Use Nullish Coalescing (??) to Handle Only Null/Undefined

Getting Session value in Javascript & Asp.Net

Use AbortController to Cancel Requests

Post Views: 5

Post navigation

HTML: Use Details and Summary for Accordion Content Without JavaScript
Ajax: Use Server-Sent Events (SSE) for Real-Time Updates Without WebSockets

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

June 2026
M T W T F S S
1234567
891011121314
15161718192021
22232425262728
2930  
« May    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (805)
  • Add Constraint to SQL Table to ensure email contains @ (580)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (579)
  • Average of all values in a column that are not zero in SQL (538)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (505)
  • Find numbers with more than two decimal places in SQL (454)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files
  • Ajax: Add Custom Headers to Fetch Requests
  • JavaScript: Use console.table to Display Arrays as Tables
  • HTML: Use Spellcheck Attribute to Enable Browser Spell Check
  • CSS: Use user-select to Prevent Text Selection
  • Windows 11: Use Snipping Tool for Instant Screenshots

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (953)
  • How to add default value for Entity Framework migrations for DateTime and Bool (882)
  • Get the First and Last Word from a String or Sentence in SQL (838)
  • How to select distinct rows in a datatable in C# (808)
  • How to make theater mode the default for Youtube (805)

Recent Posts

  • C#: Use String Interpolation Instead of Concatenation
  • C#: Use Tuples to Return Multiple Values from Methods
  • SQL: Use ISNULL and NULLIF for Smart NULL Handling
  • .NET Core: Use Data Annotations for Model Validation
  • Git: Use Git Clean to Remove Untracked Files

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com