JS中有趣的知识

1.分号与换行

function fn1(){
    return {
        name: ‘javascript‘
    };
}

function fn2(){
    return
    {
        name: ‘javascript‘
    };
}

var obj1 = fn1();
var obj2 = fn2();

console.log(obj1);
console.log(obj2);

  这个例子看上去没有什么不同,但是实质上,确实是不同的。第一个输出结果为一个object ,而第二个输出结果为undefined。为什么?

因为Js中是不需要分号和换行这个东西的,第二个会被解析成:

function fn2(){
    return ;
    {
        name: ‘javascript‘
    };
}

  所以实质上返回的是一个undefined。

2.五大类型中,关于null

Js有五大数据类型boolean,string,number,undefined,object。而为什么

typeof null

会被解析为 object 呢?

原因是在计算机底层存储数据时是以二进制格式进行存储的,如果前三位为0的话会被解析为object数据类型。而null的所有位数都为0,当解析null时,前三位先被解析,计算机错认为null为object类型,这属于计算机语言层面的一个bug。

3.关于undefined

undefined是Undefined数据类型的实例,虽然它在实际应用过程中并不能用来存储数据,但我们可以对他进行一些操作。

当我们 对Undefined数据类型名进行类型检测时

    var Undefined = 10;
    var String=10;
    console.log(typeof Undefined);
    console.log(typeof String);

显示结果为 :number number。这是因为Undefined并不是关键字和保留字。如果对关键字进行声明,会报错。

当我们对他进行数据类型检测时

console.log(typeof undefined)

显示结果为undefined。

当我们对其他数据类型进行类型检测时

console.log(typeof Object);
console.log(typeof Number);
console.log(typeof String);
console.log(typeof Boolean);

显示结果却不是数据类型本身的类型,而是function;

但是由于undefined并不是关键字和保留字,所以我们可以重新声明它

    var undefined = 10;
    var string=10;
    console.log(typeof undefined);
    console.log(typeof string);

显示结果为:number  number;可见undefined具有不变值的属性。同时开头字母小写的

   var undefined = 10;
    var string=10;
    var boolean=10;
    var object=10;
    var number=10;

    console.log(typeof undefined);
    console.log(typeof string);
    console.log(typeof object);

    console.log(typeof boolean);
    console.log(typeof number);

显示结果为:undefined number number number number 。可见同名且首字母小写的数据类型实例只有undefined一个,其他的都不是。

4.在JavaScript中不存在重载函数

    有一定后端知识的同学都知道在C++和Java中都存在函数重载,

  而JavaScript中却不存在函数重载,如果出现了,后者会把前者覆盖。而且函数声明会提升。

原文地址:https://www.cnblogs.com/bigharbour/p/11423268.html

时间: 2024-08-04 08:50:08

JS中有趣的知识的相关文章

02.5 js中的语法知识补充

1. 函数 // 带名称的函数 // function func1 (args) { // return args + 1 // } // // const func2 = function (args) { // return args + 1 // } // 直接执行的匿名函数 // (function () { // alert('这是个直接调用的匿名函数') // })() // 高阶函数, 将一个函数作为参数传入,在函数内部执行函数 function second(c, d){ ret

js中函数的一些理论知识

  函数的一些理论知识 1. 函数:                执行一个明确的动作并提供一个返回值的独立代码块.同时函数也是javascript中的一级公民(就是函数和其它变量一样). 2.函数的声明方式:                 1> 函数声明:在函数里,必须手动去声明函数的返回值,如果返回值没有申明,则此函数返回值为undefined,,return是函数内部使用的,形参能自动声明,而实参不能自动声明为undefined.我们在调用函数时要:函数+()这种形式.不然就是函数本身.

js中BOM与DOM的相关知识基础

 [函数的声明及调用] 1.>>>函数声明的格式: function 函数名(参数1,参数2,--){ // 函数体 return 结果; } >>>函数调用的格式: 直接调用:函数名(参数1的值,参数2的值,--); 事件调用:事件名=函数名(); 2.函数声明的几点强调: ① 函数名的声明,必须符合小驼峰法则(首字母小写,之后每个单词首字母大写): ② 参数列表,可以有参数,可以无参数.分别称为有参函数,无参函数: ③ 声明函数时的参数列表,称为"形参列表

js中错误处理的相关知识

错误bug是指程序执行过程中,导致程序无法正常执行的情况. 后果:程序会强行中断退出:     错误处理:                即使程序出现错误,也保证程序不异常中断的机制. 一般的使用的代码如下: try{//始终执行            //可能出现的代码 }catch(err){//只有发生错误时才执行:                         出错时执行的错误处理代码-----通知用户,记录日志,保存进度.                         err:错误

理解JS中的call、apply、bind方法

理解JS中的call.apply.bind方法(*****************************************************************) 在JavaScript中,call.apply和bind是Function对象自带的三个方法,这三个方法的主要作用是改变函数中的this指向. call.apply.bind方法的共同点和区别:apply . call .bind 三者都是用来改变函数的this对象的指向的:apply . call .bind 三者

JS中的函数、Bom、DOM及JS事件

本期博主给大家带来JS的函数.Bom.DOM操作,以及JS各种常用的数据类型的相关知识,同时,这也是JavaScript极其重要的部分,博主将详细介绍各种属性的用法和方法. 一.JS中的函数 [函数的声明及调用] 1.函数声明的格式: function 函数名(参数1,参数2,参数3,--){//函数体 return 结果; } >>>函数的调用格式: 直接调用:函数调用的格式:函数名(参数一的值,参数二的值,--): 事件调用:事件名=函数名( ); 2.函数声明的几点强调: ①函数名

js中call方法的使用介绍

js call call 方法 请参阅 应用于:Function 对象 要求 版本 5.5 调用一个对象的一个方法,以另一个对象替换当前对象. call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 参数 thisObj 可选项.将被用作当前对象的对象. arg1, arg2, , argN 可选项.将被传递方法参数序列. 说明 call 方法可以用来代替另一个对象调用一个方法.call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对

第22篇 js中的this指针的用法

前面把js的相关知识总结了下,今天把js中的上下文的this,对于强类型语言,this的用法非常的单一,因为他们没有js特有的动态绑定. 首先看下面代码: function funcA() { this.name = "hello"; console.log(this.name); this.show = function() { console.log(this.name); } } funcA();// 1.hello var a = new funcA();//2.hello a

简说JS中的循环部分

JS中的循环语句是JS基础的最最重要的部分,没有之一,后面所学的其他的一些重要的知识也是需要在此的基础啥古玩城更高级的设置,先来简单的说一下循环的一些知识点. 一.循环结构的执行步骤 1.声明循环变量: 2.判断循环条件: 3.执行循环体操作: 4.更新循环变量: 然后,循环执行2-4,直到条件不成立时,跳出循环. while循环()中的表达式,运算结果可以是各种类型.但是最终都会转为真假,转换规则同if结构. while循环特点:先判断,再执行: do-while循环特点:先执行,再判断:即使