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中却不存在函数重载,如果出现了,后者会把前者覆盖。而且函数声明会提升。
思维训练:有一个人花了800元买了一个游戏账号,又以900元卖出去,然后以1000元买回来,以1100卖出去,请问:这个人赚了多少钱?
5.Javascript中声明的name变量的数据类型会被自动转成字符
var name=10; console.log(typeof name)
显示结果为 string。
在window中有name属性--window.name为字符型。当我们声明name并赋值时,只不过是给window的name属性赋值而已,改变不了name的数据类型
JS中有趣的知识的更多相关文章
- js中有趣的闭包(closure)
一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...
- js中的对象知识总结
文章目录: 1. 比较两个对象是否相等 1. 比较两个对象是否相等 通过===运算符,只有在两个变量指向同一个对象时才返回true,否则返回false.要想比较两个对象中的内容是否相等,需要利用遍历对 ...
- JS中有趣的内置对象-JSON
前言 在以前的web开发中,我们多数选择纯文本或XML作为我们的提交的数据格式,大多数是XML,少数纯文本.其实从AJAX(Asynchronous JavaScript and XML)的命名我们也 ...
- js中实现杨辉三角
实现效果:杨辉三角 即: 提示用户输入要实现的杨辉三角行数: 请输入杨辉三角的行数: 8 代码实现后的效果如下: 1 1.1 1.2.1 1.3.3.1 1.4.6.4.1 1.5.10.10.5.1 ...
- js中函数的一些理论知识
函数的一些理论知识 1. 函数: 执行一个明确的动作并提供一个返回值的独立代码块.同时函数也是javascript中的一级公民(就是函数和其它变量一样). 2.函数的 ...
- Vue.js中Directive知识
近期所学的Vue.js这个MVVM前端技术缓解了我一直愁于前后端开发杂糅所带来的痛苦.今天就来说说关于Vue.js里面的Directive知识. Directive Directive看上去虽然和An ...
- js中错误处理的相关知识
错误bug是指程序执行过程中,导致程序无法正常执行的情况. 后果:程序会强行中断退出: 错误处理: 即使程序出现错误,也保证程序不异常中断的机制. 一般的使用的代 ...
- 二、js中基础知识
该篇文章主要是强化一下自己javaScript的基础,让写代码变得更轻松些.基础好的请忽略. JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解 ...
- 谈一谈原生JS中的【面向对象思想】
[重点提前说:面向对象的思想很重要!] 最近开始接触学习后台的PHP语言,在接触到PHP中的面向对象相关思想之后,突然想到之前曾接触的JS中的面向对象思想,无奈记性太差, ...
随机推荐
- gradlew compileDebug --stacktrace -info
gradlew compileDebug --stacktrace -info 在命令行中进入项目的根目录,或者可以在Android studio的Terminal中直接操作也可以,然后敲入一个命令: ...
- HTML超链接应用场景
页面间的连接 A页到B页,最常用,用于网络导航. 如图所示: ********************************************************************* ...
- 3.自定义返回json格式的数据给前台(自定义Controller类中的Json方法)
在mvc的项目中,我们前台做一些操作时,后台要返回一些结果给前台,这个时候我们就需要有一个状态来标识到底是什么类型的错误, 例如: 执行删除的时候,如果操作成功(1行受影响),我们需要返回状态为1并输 ...
- JavaScript-黑科技
单行写一个评级 var rate = 3; "★★★★★☆☆☆☆☆".slice(5 - rate, 10 - rate); 随机字符串 Math.random().toStrin ...
- spring微服务(顺序由简入难易于理解)
一.为微服务应用增加健康监控 1.在 build.gradle 文件 dependencies 属性中增加 compile('org.springframework.boot:spring-boot- ...
- 阿里云数据库备份DBS商业化发布,数据库实时备份到OSS
数据库备份DBS已于2018年5月17日正式商业化发布. 数据库备份(Database Backup,简称DBS)是为数据库提供连续数据保护.低成本的备份服务. 它可以为多种环境的数据提供强有力的保护 ...
- 【CF1257A】Two Rival Students【思维】
题意:给你n个人和两个尖子生a,b,你可以操作k次,每次操作交换相邻两个人的位置,求问操作k次以内使得ab两人距离最远是多少 题解:贪心尽可能的将两人往两边移动,总结一下就是min(n-1,|a-b| ...
- HashMap的底层原理 cr:csdn:zhangshixi
1. HashMap概述: HashMap是基于哈希表的Map接口的非同步实现.此实现提供所有可选的映射操作,并允许使用null值和null键.此类不保证映射的顺序,特别是它不保证该顺序恒久不变 ...
- 简单js表单验证
简单js表单验证demo <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org ...
- (转)Java并发包:AtomicBoolean和AtomicReference
转:https://blog.csdn.net/zxc123e/article/details/52057289 文章译自:http://tutorials.jenkov.com/java-util- ...