js-数据类型运算符

JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?

JavaScript共定义了六种基本类型:
数值(number):小数和整数。如12、2.2
字符串(string):字符串组成的文本。如"adc‘’
布尔值(boolean):true和false
undefined:表示“未定义”或不存在,即由于目前没有定义,所以此处暂时没有任何值。
null:表示无值,即此处的值就是“无”的状态.
对象(object):由属性/值键值对组成的集合。如{name:"小明"}

数值、字符串、布尔值为原始类型。
对象为复杂类型。

原始类型和复杂类型的区别:
原始类型:最基本的数据类型,不能再细分。
复杂类型:由多个原始类型的值组成。

typeof和instanceof的作用和区别?

typeof:
typeof运算符可以返回一个操作数类型的字符串.
如:

1.原始数据类型
typeof 1 // "number"
typeof '3' // "string"
typeof true// "boolean"
2.函数
function a(){}
typeof a;//function
3.undefined
typeof undefined  // "undefined"
4.除上面以外,其他返回的都是object
typeof window // "object"
typeof {} // "object"
typeof [] // "object"
typeof null // "object"

可以利用第3点返回一个没有声明的变量而不报错。所以对于对象来说,typeof只是用于检测该对象是否定义或者赋值。

instanceof:
instanceof运算符用来判断一个对象是否为某个构造函数的实例.
例如:

var o=new Obj();
o instanceof Obj    //true

instanceof运算符返回一个布尔值,左边是对象,右边是构造函数,实际是检查右边构造函数的原型链是否在左边的对象的原型链上。
上面等同于

 Obj.prototype.isPrototypeOf(o),

instanceof是检查原型链,所以同一个实例与原型链上构造函数运算时,结果都是true。如果对象没有原型链,就无法判断,比如null

Object.create(null) instanceof Object  //false

instanceof运算符只能用于对象,不能用于原始类型的值,如number,string,这些

Paste_Image.png

结果:

Paste_Image.png

区别

typeof的操作数可以是任意类型,instanceof只适用于对象。
typeof返回值是字符串,instanceof返回的是true或者false。

如何判断一个变量是否是数字、字符串、布尔、函数

使用typeo运算符,判断返回的字符串是否是以下几种类型的:

typeof num==="number";
typeof str==="string";
typeof b==="boolean";
typeof f==="function"

NaN是什么? 有什么特别之处?

NaN表示非数字(not a number),以下这些操作会返回NaA:
1.与NaN运算的都返回NaN。
2.未定义操作,如0/0、∞/∞
3.产生复数结果的实数运算。例如:对负数开偶次方。
4.字符串解析错误也会得到NaN:1- 'a' // NaN
虽然NaN是javascript的一种特殊的值,但是属于number类型,NaN不等于任何值,包括它自己。NaN在布尔运算时被当作false。

如何把非数值转化为数值?

1.使用parseInt()
parseInt()函数解析一个字符串并返回一个整数。
如果字符串以“0x”开头,则转为十六进制。
如果字符串以“0”开头,则转为八进制。
如果字符串以任何其他值开头,则转为十进制。
2.使用Number函数

1.如果是数值,使用Nunber转换之后还是数值。
Nunber(0);  //0
2.如果是可以解析成数值的,转换之后还是数值。
Nunber(“12”);  //12
3.如果是不可以解析成数值的字符,转换之后是NaN,
undefined转换之后也是NaN。
4.null和false、' '(空字符串)转换成0.
5.布尔值true转换成1.

两个函数都可以把非数值转换成字符串,但是Number比parseInt更严格,只要有一个是非数值的,Nunber都会转成NaN,因为parseInt逐个解析字符,而Number函数整体转换字符串的类型。

==与===有什么区别?

==:使用==时,在比较两个值之前,==将表达式的一边转换为与另一个相同的类型,如果值相等,结果是true。 例如,布尔和整数,

Paste_Image.png

说明true==1的结果是true,但是它们的类型不同,只是类型转换之后值相等。
===:===在进行比较之前不会去转换,如果类型不同,则返回false。如果类型和值都相等,就返回true。
两个不同类型,值相同的数,结果是false。
Paste_Image.png

类型和值都相同的结果是true。
Paste_Image.png

==与===两者都先检查类型,==如果类型不同就转换成相同的再比较值,===如果类型不同结果就是false,===比==更严格.

break与continue有什么区别。

break:跳出整个循环体,不会在执行循环体了。
continue:跳出本次循环,还会执行循环体的下次循环。

void 0 和 undefined在使用场景上有什么区别?

void 0 是执行一个表达式,不能被覆盖,并且始终返回值undefined。
undefined是一个值,因为undefined不是js的保留字,所以可以在函数的上下文声明一个叫做undefined的变量,并且可以给它赋值,可以把上下文内的undefined覆盖。undefined是全局对象的属性 ,所以上下文只能从全局作用域访取到undefined,所以使用void 0代替undefined,可以避免undefined被修改,也可减少从全局获取undefined的时间。

以下代码的输出结果是?为什么?

console.log(1+1);    
 结果是2,两个数是数值类型,做加法运算。
console.log("2"+"4");  
结果是‘24’,两个参数是字符串,做字符串的连接,所以得到字符串‘24’。
console.log(2+"4"); 
结果是‘24’,在有一个参数是字符串的情况下会把另外一个参数转换为字符串做字符串拼接。
console.log(+"4");
结果是4,与空字符相加会转换成数字。

. 以下代码的输出结果是?

var a = 1;  
a+++a;   // 3,++优先级高,先执行a++,此时a=1,执行完之后执行+a,这时的a是2,所以结果,1+2=3.
typeof a+2; //‘number2’,typeof优先级高于+,所以先执行typeof a,结果是‘number’,字符串和数字相加,结果是字符串的拼接,结果是“number2”。

以下代码的输出结果是? 为什么

 var a = 1;
 var b = 3;
 console.log( a+++b );//4,
++优先级高,先执行a++,a=1,再执行+b,所以1+3=4;

遍历数组,把数组里的打印数组每一项的平方(不知道这要表达什么)

 var arr = [3,4,5];
for(var i=0;i<arr.length;i++){
     console.log(arr[i]*arr[i]);
}

遍历 JSON, 打印里面的值

var obj = {
    name: 'hunger',
    sex: 'male',
    age: 28
}
for( var v in obj){
    console.log(obj[v]);
}

以下代码输出结果是? 为什么

 var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val)  // 'number2',

|| 操作符首先从左开始判断表达式的真假, 如果为真, 马上返回左边表达式返回的值。如果左边表达式被判断为假, 则继续判断右边的表达式, 并返回右边表达式的值。typeof a + b执行结果是‘number2’为true,所以不会再执行'||'后面的表达式,整个结果是||前面的值。

var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)  //undefined

&& 操作符从左开始判断表达式, 如果左边的表达式被判断为假, 这马上返回false, 不管右边的表达式是否为真。如果左边的表达式为真, 则继续判断右边的表达式, 然后返回右边表达式结果。d==5为true,继续判断右边的表达式,结果为bb。所以返回bb。

var data2 = d = 0 || console.log('haha')
console.log(data2)//haha

左边表达式为假,继续判断右边的表达式,并返回右边的值。

var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2

括号的优先级高,先执行括号里的逗号表达式(逗号运算符用于对两个表达式求值,并返回后一个表达式的值。),结果是 !!"from here!!"=!!1=1,再执行 !!"Hello" =!!1=!0=1,最后执行1+1=2.

不是很明白第2点,控制台返回的都是这样,这个undefined哪来的。

Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容