进阶任务2

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

1.1 JavaScript 定义了六种数据类型?

  • 数值(number):整数和小数(比如1和3.14)
  • 字符串(string):字符组成的文本(比如"Hello World")
  • 布尔值(boolean):true(真)和false(假)两个特定值
  • undefined:表示“未定义”或不存在,即此处目前没有任何值
  • null:表示空缺,即此处应该有一个值,但目前为空
  • 对象(object):各种值组成的集合

1.2 哪些是原始类型?哪些是复杂类型?

  • 数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再对齐进行细分
  • 对象为复杂类型(complex type)的值,一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
  • undefined和null,一般将它们看成两个特殊值。

对象又可以细分为三个子类型:

  • 狭义的对象(object)
  • 数组(array)
  • 函数(function)
  • 正则表达式 (regexp)

1.3 原始类型和复杂类型的区别是什么?

1.3.1 特性区别:

  • 原始值是固定而简单的值,是存放在栈(stack)中的简单数据段,也就是说,它们的值直接存储在变量访问的位置.原始值是表示Javascript中可用的数据或信息的最底层形式或最简单形式。原始类型的值被称为原始值,是因为它们是不可细化的。也就是说,数字是数字,字符是字符,布尔值则是true或false,null和undefined就是null和undefined。这些值本身很简单,不能表示由其他值组成的值
  • 复杂值可以由很多不同类型的javascript对象组成。复杂对象其在内存中的大小是未知的,因为复杂对象可以包含任何值,而不是一个特定的已知值,

1.3.2 存储方式区别

  • 原始值占据空间固定,是简单的数据段,为了便于提升变量查询速度,将其存储在栈(stack)中
  • 由于复杂值的大小会改变,所以不能将其存放在栈中,否则会降低变量查询速度,因此其存储在堆(heap)中,存储在变量处的值是一个指针,指向存储对象的内存处

1.3.3 访问方式的区别

  • 按值访问
    原始值是作为不可细化的值进行存储和操作的,引用它们会转移其值
  • 引用访问
    复杂值是通过引用进行存储和操作的,而不是实际的值。创建一个包含复杂对象的变量时,其值是内存中的一个引用地址。引用一个复杂对象时,使用它的名称(即变量或对象属性)通过内存中的引用地址获取该对象值

1.3.4 比较方式的区别

  • 原始值采用值比较,而复杂值采用引用比较。复杂值只有在引用相同的对象(即有相同的地址)时才相等。即使是包含相同对象的两个变量也彼此不相等,因为它们并不指向同一个对象

1.3.5 动态属性的区别

  • 对于复杂值,可以为其添加属性和方法,也可以改变和删除其属性和方法;但简单值不可以添加属性和方法
    复杂值支持动态对象属性,因为我们可以定义对象,然后创建引用,再更新对象,并且所有指向该对象的变量都会获得更新。一个新变量指向现有的复杂对象,并没有复制该对象。这就是复杂值有时被称为引用值的原因。复杂值可以根据需求有任意多个引用,即使对象改变,它们也总是指向同一个对象

1.3.6 包装类型的区别

  • 原始值被当作构造函数创建的一个对象来使用时,Javascript会将其转换成一个对象,以便可以使用对象的特性和方法,而后抛弃对象性质,并将它变回到原始值

2. typeof和instanceof的作用和区别?

2.1 typeof运算符可以返回一个值的数据类型,可能有以下结果。

  • 原始类型: 数值、字符串、布尔值分别返回number、string、boolean。
  • 函数: 返回function
  • undefined: 返回undefined。
  • 除此以外,其他情况都返回object

2.2 instanceof的作用

instanceof用于判断某个变量是否是某个对象的实例,返回值为true或false

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

typeof 变量名
如果返回值为number, 表示变量为数值;
如果返回值为string, 表示变量为字符串;
如果返回值为boolean, 表示变量为布尔运算;
如果返回值为function, 表示变量为函数;

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

NaN含义是Not a Number,表示变量类型为数值的非数字;
NaN和任何值都不相等,包括自己

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

有三个函数可以把非数值转换为数值

  • Number()
  • parseInt()
  • parseFloat()
    其中利用parseInt()及parseFloat()进行转换是会按照以下规则:
  • 忽略字符串前面的空白字符,找到第一个非空白字符
  • 如果第一个字符不是-或者数字返回NaN
  • 如果是继续解析,直到非数值模式为止
  • 0开头会当做八进制,0x开头会当做十六进制,但是可以指定第二个参数指定基数

6. " == "与 " === " 有什么区别

相等运算符" == "比较两个值是否相等,严格相等运算符" === "比较它们是否为“同一个值”。如果两个值不是同一类型,严格相等运算符" === "直接返回false,而相等运算符" == "会将它们转化成同一个类型,再用严格相等运算符进行比较。

7. break与continue有什么区别

  • break语句用于跳出代码块或循环。执行该代码块或循环的之后的内容
  • continue语句用于立即终止本轮循环,返回循环结构的头部,开始下一轮循环的执行

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

void运算符的作用是执行一个表达式,然后不返回任何值,或者说返回undefined。
在函数中,undefined可以被赋值,此时如果需要判断一个变量为undefined,可以采用 "变量 = void 表达式"的方式来判断

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

console.log(1+1);    // 2
console.log("2"+"4");  // 24
console.log(2+"4");  // 24
console.log(+"4");  // 4

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

var a = 1;  //声明变量 a,且a = 1;
a+++a;      // (a++)+a=1 + 2 = 3
typeof a+2; // (typeof a)+2 = "number"+2 = number2

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

var a = 1;  // 变量 a = 1
var b = 3;  // 变量 b = 3
console.log( a+++b ); // a+++b=(a++)+b=1 + 3 = 4, a=2, b=3

12. 遍历数组var arr = [3,4,5],把数组里的打印数组每一项的平方

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

13. 遍历 JSON, 打印里面的值

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

14. 以下代码输出结果是? 为什么 (选做题目)

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

推荐阅读更多精彩内容