1:
所有基本类型中Boolean值是false的只有6个,分别是 : 0 NaN ' ' null undefined false 引用类型Boolean值全是true.
if条件是单个值时,如果是truly值,条件成立, 如果是falsely值,条件不成立
&& 逻辑与 两边都是true,才返回true,否则返回false
|| 逻辑或 两边只要有一个是true,就返回true,否则返回false
! 逻辑非 用来取一个布尔值相反的值
数据类型判断
typeof 对于基本数据类型判断是没有问题的,但是遇到引用数据类型(如:Array)是不起作用
console.log(typeof 2); // number
console.log(typeof null); // object
`instanceof` 只能正确判断引用数据类型 而不能判断基本数据类型,其内部运行机制是判断在其原型链中能否找到该类型的原型
console.log([] instanceof Array); // true
console.log(function(){} instanceof Function); // true
console.log({} instanceof Object); // true
constructor 似乎完全可以应对基本数据类型和引用数据类型 但如果声明了一个构造函数,并且把他的原型指向了 Array 的原型,所以这种情况下,constructor 也显得力不从心
console.log((true).constructor === Boolean); // true
console.log(('str').constructor === String); // true
console.log(([]).constructor === Array); // true
console.log((function() {}).constructor === Function); // true
console.log(({}).constructor === Object); // true
console.log((2).constructor === Number); // true
Object.prototype.toString.call() 完美的解决方案,可以通过toString() 来获取每个对象的类型,
`Object.prototype.toString.call()` 使用 Object 对象的原型方法 toString 来判断数据类型:
var a = Object.prototype.toString;
console.log(a.call(2));
console.log(a.call(true));
console.log(a.call('str'));
console.log(a.call([]));
console.log(a.call(function(){}));
console.log(a.call({}));
console.log(a.call(undefined));
console.log(a.call(null));
补充:基本数据类型赋值的时候 赋的是具体的值 引用数据类型传的是地址,一个变另一个跟着变
js数据类型转换
在javascript 中有三种数据类型的转换:
1: 转换为数字类型 (调用Number(), parsetInt(), parsetFloat() 方法)
2: 转化为字符串 (调用 .toString() 或者String() 方法)
3: 转化为布尔值 (调用Boolean 方法) 还有隐式转换 注意: null underfined 没有 .toString() 方法。 调用tostring() 方法
转化为Number() 数字类型
Number(): 可以把任意数值转化成数字, 如果要转化的字符串中有不是数字的值, 则会返回NAN。
Number('1') // 值为 1
number(true) // 值为 1
Number('123s') // NAN
Number({}) // NAN
parseInt(string,radix):解析一个字符串并返回指定基数的十进制整数,radix是2-36之间的整数,表示被解析字符串的基数。
parseInt('2') //2
parseInt('2',10) // 2
parseInt('2',2) // NaN
parseInt('a123') // NaN 如果第一个字符不是数字或者符号就返回NaN
parseInt('123a') // 123
number() 可以把任意值转成数字, 如果要转成字符串中有不是数字的值, 则会返回NAN.
隐式转换
let str = '123';
let res = str -1; // '122'
str + 1; // '1231'
+ str + 1; // 124
前端面试题
最新推荐文章于 2023-08-14 17:09:28 发布