初窥 知识宝典(上)

摘要:你说这些是不是要不断学习,学以致用

面试题总结

一、基础班模块

基础部分

  1. 什么是HTML?

答:HTML并不是真正的的程序语言,他是一种标 记 语 言 ,用来结构化和含义化你想要放在web 网站上的那些内容。它由一系列的元素(elements)所组成,这些元素可以用来封装你的内容中担任不同工作的各部分和各个角色。

  1. 什么是CSS?

    答:

​ 就像 HTML,CSS 也不是真正的编程语言。它是样式表语言,也就是说,它允许你有 选择性的为 HTML 文档的元素添加样式。

  1. 行内元素和块级元素的具体区别是什么?行内元素的padding和margin可设置吗?

    答:

块级元素(block)特性:

总是独占一行,表现为另起一行开始,而且其后的元素也必须另起一行显示;

宽度(width)、高度(height)、内边距(padding)和外边距(margin)都可控制;

内联元素(inline)特性:

和相邻的内联元素在同一行;

宽度(width)、高度(height)、内边距的top/bottom(padding-top/padding-bottom)和外边距的top/bottom(margin-top/margin-bottom)都不可改变(也就是padding和margin的left和right是可以设置的),就是里面文字或图片的大小。

  1. 简述一下你对HTML语义化的理解?

    答:

a. HTML语义化让页面的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;

b. 即使在没有样式CSS 的情况下也能以一种文档格式显示,并且是容易阅读的;

c. 搜索引擎的爬虫也依赖于HTML标记来确定上下文和各个关键字的权重,有利于SEO;

d. 使阅读源代码的人更容易将网站分块,便于阅读、维护和理解;

  1. rgba() 和 opacity 设置透明度的区别是什么?

    答:

rgba()和opacity都能实现透明效果,但最大的不同是opacity作用于元素,

以及元素内的所有内容的透明度,而rgba()只作用于元素的颜色或其背景色。

(设置rgba透明的元素的子元素不会继承透明效果!)

  1. DOCTYPE的作用?

    答:

  1. <!DOCTYPE> 声明位于文档中的最前面,处于 <html> 标签之前。告知浏览器以

何种模式来渲染文档。

  1. 严格模式的排版和 JS 运作模式是以该浏览器支持的最高标准运行。
  2. 在混杂模式中,页面以宽松的向后兼容的方式显示。模拟老式浏览器的行为以防止站

点无法工作。

  1. DOCTYPE 不存在或格式不正确会导致文档以混杂模式呈现。
  1. 介绍一下你对浏览器内核的理解?都有哪些常见的浏览器内核?

    答:

​ 要或者说核心的部分是“Rendering Engine”,可大概译为“渲染引擎”,不过我们 一般习惯将之称为“浏览器内核”。负责对网页语法的解释(如标准通用标记语言下的一个 应用 HTML、JavaScript)并渲染(显示)网页。 所以,通常所谓的浏览器内核也就是浏 览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。 不同的浏览器内核对网页编写语法的解释也有不同,因此同一网页在不同的内核的浏览器里 的渲染(显示)效果也可能不同,这也是网页编写者需要在不同内核的浏览器中测试网页显 示效果的原因。 常见浏览器内核: Trident 内核:IE,MaxThon,TT,The World,360,搜狗浏览器等。[又称 MSHTML] Gecko内核:Netscape6 及以上版本,FF,MozillaSuite/SeaMonkey 等。 Presto 内核:Opera7及以上。 [Opera内核原为:Presto,现为、Blink;] Webkit 内核:Safari,Chrome 等。 [ Chrome 的:Blink(WebKit 的分支)] EdgeHTML内核:Microsoft Edge。 [此内核其实是从 MSHTML fork 而来,删掉了几 乎所有的 IE私有特性

  1. CSS选择器权重如何计算?

    答:

页面显示样式的优先级取决于其“特殊性”’,特殊性越高,就显示最高的,当特殊性相等 时,显示后者 特殊性表述为 4个部分:0,0,0,0 一个选择器的特殊性如下:

对于选择器是#id的属性值,特殊性值为:0,1,0,0 对于属性选择器,class或伪类,特殊性值为:0,0,1,0 对于标签选择器或伪元素,特殊性值为:0,0,0,1 通配符‘*’特殊性值为:0,0,0,0 内联样式特殊性值为:1,0,0,0

  1. 对WEB标准以及W3C的理解与认识?

    答:

  1. 标签闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率、使用外链 css 和 js 脚 本、结构行为表现的分离,
  2. 文件下载与页面速度更快、内容能被更多的用户所访问、内容能被更广泛的设备所 访问、更少的代码和组件,
  3. 容易维护、改版方便,不需要变动页面内容、提供打印版本而不需要复制内容、提 高网站易用性。
  1. CSS中优雅降级和渐进增强有什么区别?

答:

​ 优雅降级和渐进增强印象中是随着css3 流出来的一个概念。由于低级浏览器不支持 css3,但 css3 的效果又太优秀不忍放弃,所以在高级浏览中使用 css3 而低级浏览器只保证 最基本的功能。咋一看两个概念差不多,都是在关注不同浏览器下的不同体验,关键的区别 是他们所侧重的内容,以及这种不同造成的工作流程的差异。

“优雅降级”观点认为应该针对那些最高级、最完善的浏览器来设计网站。 “渐进增强”观点则认为应关注于内容本身。

  1. 对BFC规范的理解有哪些?

    答:

  1. 定义:

BFC(Block formatting context)直译为”块级格式化上下文”。它是一个独立的渲染区域, 只有 Block-level box 参与,它规定了内部的Block-level Box 如何布局,并且与这个区域 外部毫不相干。 布局规则:

​ A. 内部的Box 会在垂直方向,一个接一个地放置。 ​ B. Box垂直方向的距离由 margin决定。属于同一个 BFC的两个相邻 Box的 margin 会发 生重叠。 ​ C. 每个元素的 margin box 的左边,与包含块border box 的左边相接触(对于从左往右的 格式化,否则相反)。即使存在浮动也是如此。 ​ D. BFC 的区域不会与 float box 重叠。 ​ E. BFC 就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反 之也如此。 ​ F. 计算 BFC 的高度时,浮动元素也参与计算。

  1. 哪些元素会生成 BFC:

    A. 根元素 B. float 属性不为 none C. position为 absolute 或 fixed D. display为inline-block, table-cell, table-caption, flex, inline-flex F. overflow 不为 visible

  1. 有多少种清除浮动的方法?

    答:

    1. 父级div定义 height

    原理:父级 div手动定义 height,就解决了父级 div无法自动获取到高度的问题。 简单、 代码少、容易掌握 ,但只适合高度固定的布局.

    1. 结尾处加空 div标签 clear:both

    原理:在浮动元素的后面添加一个空div兄弟元素,利用 css 提高的clear:both清除浮动, 让父级div能自动获取到高度 ,如果页面浮动布局多,就要增加很多空 div,让人感觉很 不好 .

    1. 父级div定义 伪类:after 和 zoom

    /清除浮动代码/ .clearfix:after{ content:”“; display:block; visibility:hidden; height:0; line-height:0; clear:both; } .clearfix{zoom:1} 原理:IE8以上和非 IE浏览器才支持:after,原理和方法 2有点类似,zoom(IE专有属性) 可解决ie6,ie7 浮动问题 ,推荐使用,建议定义公共类,以减少CSS 代码。

    1. 父级div定义 overflow:hidden

    超出盒子部分会被隐藏,不推荐使用.

    1. 双伪元素法: .clearfix:before,.clearfix:after { content: ““; display: block; clear:both; } .clearfix { zoom: 1;}

实际工作部分

  1. HTML常见兼容性问题?

    答:

  1. 双边距BUG float引起的 使用display

  2. 3像素问题 使用float引起的 使用dislpay:inline -3px

  3. 超链接hover 点击后失效 使用正确的书写顺序 link visited hover active

  4. Iez-index问题 给父级添加position:relative

  5. Png透明 使用js代码改

  6. Min-height最小高度 !Important解决’

  7. select在ie6下遮盖使用iframe嵌套

  8. 为什么没有办法定义1px左右的宽度容器(IE6默认的行高造成的,使用over:hidden,zoom:0.08line-height:1px)

  9. IE5-8不支持opacity,解决办法:

    .opacity{

    ​ opacity: 0.4

    ​ filter: alpha(opacity=60); /* for IE5-7 */

    ​ -ms-filter:”progid:DXImageTransform.Microsoft.Alpha(Opacity=60)”; /* for IE 8*/

    }

  10. IE6不支持PNG透明背景,解决办法: IE6下使用gif图片

  1. 描述一个”reset”的CSS文件并如何使用它。知道**normalize.css**吗?你了解他们的不同之处?

    答:

​ 重置样式非常多,凡是一个前端开发人员肯定有一个常用的重置CSS文件并知道如何使用它们。他们是盲目的在做还是知道为什么这么做呢?原因是不同的浏览器对一些元素有不同的默认样式,如果你不处理,在不同的浏览器下会存在必要的风险,或者更有戏剧性的性发生。

  你可能会用Normalize来代替你的重置样式文件。它没有重置所有的样式风格,但仅提供了一套合理的默认浏览器达到一致和合理,但又不扰乱其他的东西(如粗体的标题)。

  在这一方面,无法做每一个复位重置。它也确实有些超过一个重置,它处理了你永远都不用考虑的怪癖,像HTML一致或line-height不一致。

  1. BFC是什么?

    答:

BFC(块级格式化上下文),一个创建了新的BFC的盒子是独立布局的,盒子内元素的布局不会影响盒子外面的元素。在同一个BFC中的两个相邻的盒子在垂直方向发生margin重叠的问题

BFC是指浏览器中创建了一个独立的渲染区域,该区域内所有元素的布局不会影响到区域外元素的布局,这个渲染区域只对块级元素起作用

  1. 怎样实现三栏布局,两边宽度固定,中间自适应?

    答:

圣杯布局 双飞翼布局

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
        }

        #left {
            width: 200px;
            height: 200px;
            float: left;
            background-color: red;
        }

        #right {
            width: 150px;
            height: 200px;
            float: right;
            background-color: mistyrose;
        }

        #middle {
            height: 200px;
            margin: 0 150px 0 200px;
            background-color: saddlebrown;
            word-break: break-word;
        }
    </style>
</head>
<body>
<div id="content">
    <div id="left">我是左侧内容我是左侧内容我是左侧内容我是左侧内容我是左侧内容</div>
    <div id="right">我是右侧内容我是右侧内容我是右侧内容我是右侧内容我是右侧内容我是右侧内容</div>
    <div id="middle">我是中间内容我是中间内容我是中间内容我是中间内容我是中间内容我是中间内容我是容我是中间内容我是中间内容</div>
</div>
</body>
</html>
  1. 精灵图(CSS Sprites)的优点和缺点

    答:

精灵图是一种网页图片应用处理方式。就是把网页中很多小背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background-repeat”,“background-position”的组合进行背景图显示及定位,达到显示某一部分背景图的效果。

精灵图的优点:

少图片的体积,因为每个图片都有一个头部信息,把多个图片放到一个图片里,就会共用同一个头部信息,从而减少了字节数。

  1. 减少了网页的http请求次数,从而加快了网页加载速度,提高用户体验。
  2. 解决了网页设计师在图片命名上的困扰,只需对一张集合的图片上命名就可以了,不需要对每一个小元素进网页的制作效率。
  3. 更换风格方便,只需要在一张或少张图片上修改图片的颜色或样式,整个网页的风格就可以改变。维护起来更加方便。

精灵图的缺点:

  1. 在图片合并的时候,你要把多张图片有序的合理的合并成一张图片,还要留好足够的空间,防止板块内出现还好,最痛苦的是在宽屏,高分辨率的屏幕下的自适应页面,你的图片如果不够宽,很容易出现背景断裂;
  2. 在开发的时候比较麻烦,你要通过photoshop或其他工具测量计算每一个背景单元的精确位置,这是针线活,繁琐;
  3. 在维护的时候比较麻烦,如果页面背景有少许改动,一般就要改这张合并的图片,无需改的地方最好不要动的css,如果在原来的地方放不下,又只能(最好)往下加图片,这样图片的字节就增加了,还要改动css。
  4. 精灵图不能随意改变大小和颜色。精灵图改变大小会失真模糊,降低用户体验,css3新属性可以改变精灵图颜色,但是比较麻烦,并且新属性有兼容问题。现在一般都是用web字体(图标字体)来代替精灵图。

二、JavaScript基础模块

基础部分

  1. JS中有哪些数据类型?

    答:

简单数据类型:Undefined、Null、Boolean、Number 和String。 复杂数据类型:Object

  1. ”==” 和 “===” 的区别?

    答:

前者会自动转换类型,而后者不会。

前者比较的是值,后者比较的是值和类型。

  1. JS中的常用内置对象有哪些?并列举该对象的常用方法?

    答:

  1. Arguments 函数参数集合

    arguments[ ] 函数参数的数组

    Arguments 一个函数的参数和其他属性

    Arguments.callee 当前正在运行的函数

    Arguments.length 传递给函数的参数的个数

  2. Array 数组

    length属性 动态获取数组长度

    join() 将一个数组转成字符串。返回一个字符串。

    reverse() 将数组中各元素颠倒顺序

    delete运算符 只能删除数组元素的值,而所占空间还在,总长度没变(arr.length)。

    shift() 删除数组中第一个元素,返回删除的那个值,并将长度减 1。

    pop() 删除数组中最后一个元素,返回删除的那个值,并将长度减1。

    unshift() 往数组前面添加一个或多个数组元素,长度要改变。

    push() 往数组结尾添加一个或多个数组元素,长度要改变。

    concat( ) 连接数组

    slice( ) 返回数组的一部分

    sort( ) 对数组元素进行排序

    splice( ) 插入、删除或替换数组的元素

    toLocaleString( ) 把数组转换成局部字符串

    toString( ) 将数组转换成一个字符串

  3. Boolean 布尔对象

    Boolean.toString( ) 将布尔值转换成字符串

    Boolean.valueOf( ) Boolean对象的布尔值

  4. Error 异常对象

    Error.message 可以读取的错误消息

    Error.name 错误的类型

    Error.toString( ) 把Error 对象转换成字符串

    EvalError 在不正确使用 eval()时抛出

    SyntaxError 抛出该错误用来通知语法错误

    RangeError 在数字超出合法范围时抛出

    ReferenceError 在读取不存在的变量时抛出

    TypeError 当一个值的类型错误时,抛出该异常

    URIError 由URl的编码和解码方法抛出

  5. Function 函数构造器

    Function 函数构造器

    Function.apply( ) 将函数作为一个对象的方法调用

    Function.arguments[] 传递给函数的参数

    Function.call( ) 将函数作为对象的方法调用

    Function.caller 调用当前函数的函数

    Function.length 已声明的参数的个数

    Function.prototype 对象类的原型

    Function.toString( ) 把函数转换成字符串

  6. Math 数学对象

    Math对象是一个静态对象

    Math.PI 圆周率。

    Math.abs() 绝对值。

    Math.ceil() 向上取整(整数加 1,小数去掉)。

    Math.floor() 向下取整(直接去掉小数)。

    Math.round() 四舍五入。

    Math.pow(x,y) 求 x的y次方。

    Math.sqrt() 求平方根。

  7. Number 数值对象

    Number.MAX_VALUE 最大数值

    Number.MIN_VALUE 最小数值

    Number.NaN 特殊的非数字值

    Number.NEGATIVE_INFINITY 负无穷大

    Number.POSITIVE_INFINITY 正无穷大

    Number.toExponential( ) 用指数计数法格式化数字

    Number.toFixed( ) 采用定点计数法格式化数字

    Number.toLocaleString( ) 把数字转换成本地格式的字符串

    Number.toPrecision( ) 格式化数字的有效位

    Number.toString( ) 将—个数字转换成字符串

    Number.valueOf( ) 返回原始数值

  8. Object 基础对象

    Object 含有所有 JavaScript 对象的特性的超类

    Object.constructor 对象的构造函数

    Object.hasOwnProperty( ) 检查属性是否被继承

    Object.isPrototypeOf( ) 一个对象是否是另一个对象的原型

    Object.propertyIsEnumerable( ) 是否可以通过 for/in循环看到属性

    Object.toLocaleString( ) 返回对象的本地字符串表示

    Object.toString( ) 定义一个对象的字符串表示

    Object.valueOf( ) 指定对象的原始值

  9. RegExp 正则表达式对象

    RegExp.exec( ) 通用的匹配模式

    RegExp.global 正则表达式是否全局匹配

    RegExp.ignoreCase 正则表达式是否区分大小写

    RegExp.lastIndex 下次匹配的起始位置

    RegExp.source 正则表达式的文本

    RegExp.test( ) 检测一个字符串是否匹配某个模式

    RegExp.toString( ) 把正则表达式转换成字符串

  10. String 字符串对象

Length 获取字符串的长度。

toLowerCase() 将字符串中的字母转成全小写。

toUpperCase() 将字符串中的字母转成全大写。

charAt(index) 返回指定下标位置的一个字符。如果没有找到,则返回空字符串。

substr() 在原始字符串,返回一个子字符串

substring() 在原始字符串,返回一个子字符串。

split() 将一个字符串转成数组。

charCodeAt( ) 返回字符串中的第 n个字符的代码

concat( ) 连接字符串

fromCharCode( ) 从字符编码创建—个字符串

indexOf( ) 返回一个子字符串在原始字符串中的索引值(查找顺序从左往右查找)。如果没 有找到,则返回-1。

lastIndexOf( ) 从后向前检索一个字符串

localeCompare( ) 用本地特定的顺序来比较两个字符串

match( ) 找到一个或多个正则表达式的匹配

replace( ) 替换一个与正则表达式匹配的子串

search( ) 检索与正则表达式相匹配的子串

slice( ) 抽取一个子串

toLocaleLowerCase( ) 把字符串转换小写

toLocaleUpperCase( ) 将字符串转换成大写

toLowerCase( ) 将字符串转换成小写

toString( ) 返回字符串

toUpperCase( ) 将字符串转换成大写

valueOf() 字符串

  1. 什么是闭包?

    答:

简单的说,作用域是针对变量的,比如我们创建一个函数a1,函数里面又包了一 个子函数 a2。此时就存在三个作用域: 全局作用域、a1作用域、a2 作用域;即全局作用域包含了a1的作用域,a2 的作用 域包含了 a1的作用域。 当a1 在查找变量的时候会先从自身的作用域区查找,找不到再到上一级a2 的作用域 查找,如果还没找到就到全局作用域区查找,这样就形成了一个作用域链。 理解闭包首先要理解,js 垃圾回收机制,也就是当一个函数被执行完后,其作用域会被 收回,如果形成了闭包,执行完后其作用域就不会被收回。 如果某个函数被他的父函数之外的一个变量引用,就会形成闭包。 闭包的作用,就是保存自己私有的变量,通过提供的接口(方法)给外部使用,但外部 不能直接访问该变量。

  1. 什么是原型链?

    答:

Javascript 是面向对象的,每个实例对象都有一个__proto_属性,该属性指向它原 型对象,这个实例对象的构造函数有一个原型属性 prototype,与实例的__proto__属性指 向同一个对象。当一个对象在查找一个属性的时,自身没有就会根据__proto__ 向它的原型 进行查找,如果都没有,则向它的原型的原型继续查找,直到查到 Object.prototype._proto_为null,这样也就形成了原型链。

  1. 有哪些方式继承?

    答:

  1. 借用构造函数。也叫伪造对象或经典继承。 思路:在子类构造函数的内部调用超类型构造函数。可以通过使用 apply()和call()方法 在新创建的对象上执行构造函数。 缺点:方法都在构造函数中定义,函数的复用就无从谈起。在超类型的原型中定义的方 法,对子类而言也是不可见的,结果所有的类型都只能使用构造函数模式。
  2. 组合继承。也叫伪经典继承。指的是将原型链和借用构造函数的技术组合到一起, 从而发挥二者之长。 思路:使用原型链实现对原型属性属性和方法的继承,通过借用构造函数来实现实例属 性的继承。 优点:既通过在原型上定义方法实现了函数复用,又能保证每一个实例都有它自己的数 组。 组合继承避免了原型链和借用构造函数的缺陷,融合了他们的优点,成为 JavaScript 中常用的继承模式。
  3. 原型链继承。 思路:借助原型可以基于已有的对象创建对象,同时还不必因此创建自定义类型。 在object()函数内部,先创建一个临时的构造函数,然后将传入的对象作为这个构造函 数的原型,最后返回了这个临时类型的一个新实例。
  4. 寄生式继承。 思路:创建一个仅用于封装继承过程的函数,该函数在内部以某种方式来增强对象,最 后再像真的是它做了所有的工作一样返回对象。缺点:使用寄生式继承来为对象添加函数,会由于不能做到函数复用二降低效率,这一 点和构造函数模式类似。
  5. )寄生组合式继承。是JavaScript 最常用的继承模式。 思路:通过借用构造函数来继承属性,通过原型链的混成形式来继承方法。 本质上,就是使用寄生式继承来继承超类型的原型,然后再将结果指定给子类型的原型。 开发人员普遍认为寄生组合式继承时引用类型最理想的继承范式。 extend()方法才用了这样的方式。
  1. 字符创的常用方法有哪些?

    答:

charCodeAt 方法返回一个整数,代表指定位置字符的 Unicode 编码;

charAt方法返回指定索引位置处的字符。如果超出有效范围的索引值返回空字符串;

slice方法返回字符串的片段;

substring方法返回位于String 对象中指定位置的子字符串。

substr方法返回一个从指定位置开始的指定长度的子字符串。

indexOf方法返回 String 对象内第一次出现子字符串位置。如果没有找到子字符串, 则返回-1;

lastIndexOf方法返回 String对象中字符串最后出现的位置。如果没有匹配到子字符 串,则返回-1;

search方法返回与正则表达式查找内容匹配的第一个字符串的位置。

concat 方法返回字符串值,该值包含了两个或多个提供的字符串的连接;

split 将一个字符串分割为子字符串,然后将结果作为字符串数组返回;

  1. DOM节点的增删改查?

    答:

  1. 创建节点、追加节点

    createElement(标签名)创建一个元素节点(具体的一个元素)。

    createTextNode(节点文本内容)创建一个文本节点。

    createDocumentFragment() //创建一个 DOM 片段。

    appendChild(节点)追加一个节点。

  2. 插入节点

    appendChild(节点)也是一种插入节点的方式,还可以添加已经存在的元素,会将其 元素从原来的位置移到新的位置。

    insertBefore(a,b)是参照节点,意思是 a节点会插入 b节点的前面。

  3. 删除、移除节点

    removeChild(节点) 删除一个节点,用于移除删除一个参数(节点)。其返回的被移除 的节点,被移除的节点仍在文档中,只是文档中已没有其位置了。

  4. 复制节点

    cloneNode() 方法,用于复制节点, 接受一个布尔值参数, true 表示深复制(复制节点 及其所有子节点), false 表示浅复制(复制节点本身,不复制子节点)。

  5. 替换节点

    replaceChild(插入的节点,被替换的节点) ,用于替换节点,接受两个参数,第一参数 是要插入的节点,第二个是要被替换的节点。返回的是被替换的节点。

  6. 查找节点

    getElementsByTagName() //通过标签名称 getElementsByName() //通过元素的Name 属性的值(IE容错能力较强,会得到一 个数组,其中包括 id等于 name值的) getElementById() //通过元素 Id,唯一性

  1. 什么是预解析?

    答:

在代码整体执行之前,先解析一部分。

预解析之后,代码才会从上往下依次整体执行,但是预解析执行过的代码不会 重复执行。

js预解析干了什么事:js 中预解析会把声明部分的代码预先执行。

声明相关的代码可以分为两部分:

1、 变量声明 通过 var关键字定义的变量。

2、函数声明 通过 function关键字声明的函数

预解析时如果遇到重复的变量声明,那么忽略。

预解析时如果遇到重复的函数声明,保留后面的函数。

预解析时如果遇到变量与函数重名的情况,保留函数。

  1. 什么是变量名提升?

答:

使用 var关键字定义的变量,被称为变量声明;

函数声明提升的特点是,在函数声明的前面,可以调用这个函数。

  1. JS中的typeof关键字能返回哪些数据类型?

    答:

typeof一般判断基本数据类型。是一个操作符而不是函数,圆括号可有可无。

typeof 返回值有:string,number,boolean,undefined,object ,function,

基本数据类型:Boolean、Number、String、Undefined、Null

基本数据类型中数字,字符串,布尔类型返回其对类型 undefined返回 undefined

九大内置构造函数及其他所有函数返回function;

其他所有复杂类型对象和null返回 object

  1. 简述创建函数的几种方式?

    答:

  1. 函数声明

    function sum1(num1,num2){

    ​ return num1+num2;

    }

  2. 函数表达式

    var sum2 = function(num1,num2){

    ​ return num1+num2;

    }

  3. 函数对象方式

    var sum3 = new Function(“num1”,”num2”,”return num1+num2”);

  1. 代码实现数组排序并去重

    答:

    function fn(arr){
      for(var i = 0; i < arr.length-1; i++){
        for(var j = 0; j < arr.length-1-i; j++){
          if(arr[j]<arr[j+1]){
            var temp = arr[j];
            arr[j] = arr[j+1];
            arr[j+1] = temp;
          }
        }
      }
      for(var k = 0; k < arr.length; k++){
        var c = arr[k];
        for(var l = k+1; l < arr.length; l++){
          if(arr[l] == c){
            arr.splice(l, 1);
            l--;
          }
        }
      }
      return arr
    }
    var arr = [1, 2, 5, 6, 8, 9, 10, 6, 5, 7, 4, 3, 5]
    console.log(fn(arr))
    

14.写出下面代码输出的结果 A. console.log( undefined || 1 ); –> 1

​ B. console.log( null NaN ); –> NaN

​ C. console.log( 0 && 1 ); –> 0 D. console.log( 0 && 1 || 0 ); –> 0

  1. 下列代码将会输出什么?

    var foo = 1;
    function fn() {
      console.log( foo );   -->  undefined
      var foo = 2;
      console.log( foo );   -->  2
    }
    fn();
    

实际工作部分

  1. 什么是短路表达式?

    答:

短路表达式只是一种简写形式,也就是用 && 和 来赋值或者执行函数的形式

例如:

var foo = foo1 foo2;

意思是如果foo1是真的,那么就把foo1的值赋给foo,否则把foo2的值赋给foo。

foo && foo()

当foo存在的时候,我们就执行foo函数,如果这个时候foo不是一个函数,就会报错,所以这个只是一种简写形式而已。

  1. 控制台中使用哪些部分调试?

    答:

主要用console来进行调试

  1. console.log 用于输出普通信息
  2. console.info 用于输出提示性信息
  3. console.error用于输出错误信息
  4. console.warn用于输出警示信息
  5. console.debug用于输出调试信息