CHALLENGE
let x = 1;
function outer() {
let x = 2;
function inner() {
console.log(x);
let x = 3;
}
inner();
}
outer();
π6β€2
  What is the output?
  Anonymous Quiz
    46%
    2
      
    37%
    ReferenceError: Cannot access 'x' before initialization
      
    8%
    1
      
    10%
    undefined
      
    π€18π10β€5π€£2
  A curious quirk of TypeScriptβs type system is that it is Turing-complete which has led some developers to implement apps entirely in the type system. One such developer has spent eighteen months producing 177 terabytes of types to get 1993βs Doom running with them. Ridiculous and amazing in equal measure, he
Sarah Gooding (Socket)
Please open Telegram to view this post
    VIEW IN TELEGRAM
  π8β€5π₯4
  CHALLENGE
const user = {
  name: 'John',
  greet() {
    const getName = () => {
      console.log(this.name);
    };
    getName();
  },
  farewell: function() {
    function getName() {
      console.log(this.name);
    }
    getName();
  }
};
user.greet();
user.farewell();π2
  What is the output?
  Anonymous Quiz
    33%
    John undefined
      
    41%
    John John
      
    14%
    undefined undefined
      
    13%
    undefined John
      
    π€16π15π€£5β€4π₯4
  A mature Svelte component library for creating interactive node-based UIs and diagrams. v11 adds the ability to toggle between βsnap gridβ and freeform modes for manipulating elements. (Thereβs a live demo at the bottom of the homepage.)
Open Source Labs
Please open Telegram to view this post
    VIEW IN TELEGRAM
  π4π₯2β€1
  CHALLENGE
const arr = [1, 2, 3, 4, 5];
const result = arr
.map(x => x * 2)
.filter(x => x > 5)
.reduce((acc, val) => {
return acc + (val % 3 === 0 ? val : 0);
}, 0);
console.log(result);
π12
  π16β€7π€6
  This media is not supported in your browser
    VIEW IN TELEGRAM
  Thank You for 30k! π«‘ 
Weβve just hit a major milestone: 30,000 subscribers!β‘οΈ 
Thank you for being part of our community. Your support and engagement mean the world to us, and weβre excited to keep bringing you the content you love.
Stay tuned for more updates and great things ahead!
P.S. Play the video with the sound on.
@JavaScript Newsletter Team
βοΈ   Check out our emoji pack here
π€  Collaboration
Weβve just hit a major milestone: 30,000 subscribers!
Thank you for being part of our community. Your support and engagement mean the world to us, and weβre excited to keep bringing you the content you love.
Stay tuned for more updates and great things ahead!
P.S. Play the video with the sound on.
@JavaScript Newsletter Team
Please open Telegram to view this post
    VIEW IN TELEGRAM
  2π20β€9π€©5π₯2
  CHALLENGE
const items = new WeakSet();
const obj1 = { id: 1 };
const obj2 = { id: 2 };
items.add(obj1);
items.add(obj2);
obj2.value = 'test';
console.log(items.has(obj2));
obj2 = null;
setTimeout(() => {
console.log(items.has(obj2));
}, 0);
π9
  What is the output?
  Anonymous Quiz
    20%
    TypeError, TypeError
      
    32%
    true, undefined
      
    37%
    true, false
      
    10%
    true, TypeError
      
    π₯11π€10π4β€2π€£2
  Media is too big
    VIEW IN TELEGRAM
  A quick example of how one can "synchronize" a 3d scene across multiple windows using three.js and localStorage
bgstaal
Please open Telegram to view this post
    VIEW IN TELEGRAM
  β€19π₯13π€©5π€£2π€1
  CHALLENGE
function* range(start, end) {
  let current = start;
  while (current <= end) {
    if (current % 3 === 0) {
      current++;
      continue;
    }
    yield current++;
  }
}
const gen = range(4, 10);
const result = [...gen];
console.log(result);π5
  What is the output?
  Anonymous Quiz
    30%
    [4, 5, 6, 7, 8, 9, 10]
      
    19%
    [4, 5, 6, 7, 8, 10]
      
    10%
    [4, 5, 7, 8, 9, 10]
      
    41%
    [4, 5, 7, 8, 10]
      
    β€12π₯5π€4π€£2π1
  CHALLENGE
async function demo() {
  console.log('1');
  
  setTimeout(() => console.log('2'), 0);
  
  Promise.resolve().then(() => {
    console.log('3');
    setTimeout(() => console.log('4'), 0);
  });
  
  await Promise.resolve();
  console.log('5');
  
  queueMicrotask(() => console.log('6'));
}
demo();
console.log('7');π12π₯3β€1
  What is the output?
  Anonymous Quiz
    24%
    1, 7, 5, 3, 6, 2, 4
      
    36%
    1, 7, 3, 5, 6, 2, 4
      
    28%
    1, 3, 5, 6, 7, 2, 4
      
    12%
    1, 7, 3, 5, 2, 6, 4
      
    π€8π₯5β€1π1
  Four months in the making, TypeScript 5.8 lands with a strong Node focus. You can now use require() for ES modules in the nodenext module, thereβs a new node18 module for developers who want to keep targeting Node 18, and most notably thereβs now an --erasableSyntaxOnly option to ensure no TypeScript-only runtime semantics can be used (ideal if youβre using Nodeβs type stripping features to run TypeScript code directly).
Microsoft
Please open Telegram to view this post
    VIEW IN TELEGRAM
  π8β€4π₯1
  CHALLENGE
const config = {
  port: 0,
  timeout: null,
  retries: '',
  cache: false,
  debug: undefined
};
const port = config.port ?? 3000;
const timeout = config.timeout ?? 5000;
const retries = config.retries ?? 3;
const cache = config.cache ?? true;
const debug = config.debug ?? false;
console.log([port, timeout, retries, cache, debug]);π10
  What is the output?
  Anonymous Quiz
    18%
    [3000, null, 3, false, false]
      
    34%
    [0, 5000, '', false, false]
      
    12%
    [0, 5000, '', false, true]
      
    37%
    [3000, 5000, 3, true, false]
      
    π₯17π12π€10β€1
  A basic template app that uses React 19, Tailwind CSS 4, shadcn/ui, Electron Vite, Biome, and includes a GitHub Actions release workflow.
Dalton Menezes
Please open Telegram to view this post
    VIEW IN TELEGRAM
  π7β€2π₯2
  CHALLENGE
const team = {
  captain: { name: 'Jack', age: 35 },
  players: ['Bob', 'Alice', 'Mike'],
  details: { founded: 2020, league: 'Premier' }
};
const { 
  captain: { name }, 
  players: [, second],
  details: { league: division = 'Amateur' } 
} = team;
console.log(`${name}-${second}-${division}`);π€£12π5β€4
  