JavaScript is a little weird!!

umangm05 - Apr 20 '22 - - Dev Community

Hey Folks, Hope you're all doing great.

Today, I wanted to talk about some weird things that are really really weird about Javascript language and not only in JS, some of them are also applicable in other programming languages.

Let's start with the basics.

What is Javascript?

Well, Javascript is a scripting language that conforms to the ECMAScript standard. And you know, its initial release was built in only ten days back in December, 1995.

What I was talking about.

But Js is a little bit wierd and it doesn't always behave the way you might think and does not produce the expected output.

Note: Even senior JS developers don't use some of these syntax'es. This post is just for showing how quirky js can get.

Talk is cheap, show me the code

Here you go,

if(0.2+0.1 == 0.3){
  console.log("Foo");
}else{
  console.log("bar");
}
Enter fullscreen mode Exit fullscreen mode

Output: bar
Try to expect the output, you might say it will log out "Foo". But that's the catch, if you do something like this you can see why it logs "bar".

That's just the problems with the programming languages not particularly with js. Programming languages lacks the base 10 accuracy. Let's see what I mean.

console.log(0.2+0.1);   //0.30000000000000004
Enter fullscreen mode Exit fullscreen mode

So obviously, 0.30000000000000004 is not equals to 0.3

Okay, the next one.

console.log([,].length);  //1
Enter fullscreen mode Exit fullscreen mode

So, the array has 2 elements, right? One before the comma and one after that (Even though they are empty). But JS treats this as only 1 element. In Js, until and unless you pass the value to the last position (after the last comma) of the array, it will not treat this as a value and will not insert it into the array but that's not the case with the other positions.
The last comma is called the trailing comma
And you will find it everywhere in the JS code, like

const example = {
    foo: "foo",
    bar: "bar", // 👈🏻 here you can see a trailing comma
};
Enter fullscreen mode Exit fullscreen mode

Here's the example.

console.log([1,2,].length);  //2
console.log([,,3].length);   //3
Enter fullscreen mode Exit fullscreen mode

Here, when you pass nothing in the last position, the array's length is 2 but when you pass only the last position it still counts all the other values.

One More
We all at one or the other point in time of our coding journey used increment operator.
Let's look at that in JS.

console.log(++1);  //Error
console.log(++true);  //Error
Enter fullscreen mode Exit fullscreen mode

Well, to be honest, it's giving an error not because of JS, but due to the fact that we are trying to mutate an already defined value.

You might say that increment operator might not exists in Js. But let me tell you that the syntax is absolutely correct.

let foo=1;
console.log(++foo);  //2
let bar = true;
console.log(++bar);  //2 
Enter fullscreen mode Exit fullscreen mode

This is a valid syntax but it only works with variables.
And this is not the case with Js only, it works the same way with Java, C and many more programming languages.

The last one

console.log((10,2));  //2
console.log((2+1,3+1,1));  //1
console.log((2-1,3*1,1+1));  //2
Enter fullscreen mode Exit fullscreen mode

The comma operator evaluates its operands, from left to right, but returns only the last operand.

The definitely last one

const arr1 = ["a","b","c"];
const arr2 = [1,2,3];
console.log(arr1+arr2);  // a,b,c1,2,3
Enter fullscreen mode Exit fullscreen mode

This happens because when you try to concat two array's, they will first get converted into strings and are then concatenated.

If you really need to concat two arrays, you should use the "spread" operator.

const arr1 = ["a","b","c"];
const arr2 = [1,2,3];
console.log([...arr1 , ...arr2 ]);  //[ 'a', 'b', 'c', 1, 2, 3 ]
Enter fullscreen mode Exit fullscreen mode

Final Thoughts

So, I think you all might agree with me on the fact that js is a little funny language and does not works the same we think it does.

If you think Js is not wierd enough, please let me know in the comments below and I will probably make another post about the more quirks that Js has.

Okay, so that's Umang Mittal signing off.

. . . .
Terabox Video Player