JavaScript面试开发常用的知识点总结


Posted in Javascript onAugust 08, 2016

No1.语法和类型
 1.声明定义
 变量类型:var,定义变量;let,定义块域(scope)本地变量;const,定义只读常量。
 变量格式:以字母、下划线“_”或者$符号开头,大小写敏感。
 变量赋值:声明但未赋值的变量在使用时值为undefined,未声明的变量直接使用会抛异常。
 未赋值变量作计算:结果为NaN。例如:
 var x, y = 1;
console.log(x + y); //结果为NaN,因为x没有赋值。
2.作用域
 变量作用域:在ES6之前没有块声明域,变量作用于函数块或者全局。如下面的代码输入的x为5。

if (true) {
var x = 5;
}
console.log(x); // 5

ES6变量作用域:ES6支持块作用域,但需要使用let声明变量。下面的代码输出结果抛出异常。

i f (true) {
let y = 5;
}
console.log(y); // ReferenceError: y is not defined1234

变量上浮:在一个方法或者全局代码中,我们在生命变量之前使用变量时并没有抛异常,而是返回undefined。这是因为javascript自动把变量的声明上浮到函数或者全局的最前面。如下面的代码:

/**
* 全局变量上浮
*/
console.log(x === undefined); // logs "true"
var x = 3;

/**
* 方法变量上浮
*/
var myvar = "my value";
// 打印变量myvar结果为:undefined
(function() {
console.log(myvar); // undefined
var myvar = "local value";
})(); 
上面代码和下面代码是等价的:
 /**
* 全局变量上浮
*/
var x;
console.log(x === undefined); // logs "true"
x = 3;

/**
* 方法变量上浮
*/
var myvar = "my value";
(function() {
var myvar;
console.log(myvar); // undefined
myvar = "local value";
})();

全局变量:在页面中,全局对象是window,所以我们访问全局变量可通过window.variable。例如:

version = "1.0.0";
console.log(window.version); //输出1.0.0

No2.数据结构和类型 
1.数据类型 
6个基础类型:Boolean(true或者false)、null(js大小写敏感,和Null、NULL是有区别的)、undefined、Number、String、Symbol(标记唯一和不可变)
 一个对象类型:object。
 object和function:对象作为值的容器,函数作为应用程序的过程。 
2.数据转换 
函数:字符串转换为数字可使用parseInt和parseFloat方法。 
parseInt:函数签名为parseInt(string, radix),radix是2-36的数字表示数字基数,例如十进制或者十六进制。返回结果为integer或者NaN,例如下面输出结果都为15。

parseInt("0xF", 16);
parseInt("F", 16);
parseInt("17", 8);
parseInt(021, 8);
parseInt("015", 10);
parseInt(15.99, 10);
arseInt("15,123", 10);
parseInt("FXX123", 16);
parseInt("1111", 2);
parseInt("15*3", 10);
parseInt("15e2", 10);
parseInt("15px", 10);

parseFloat:函数签名为parseFloat(string),返回结果为数字或者NaN。例如:

parseFloat("3.14"); //返回数字
parseFloat("314e-2"); //返回数字
parseFloat("more non-digit characters"); //返回NaN

3.数据类型文本化
文本化类型:Array、Boolean、Floating-point 、integers、Object、RegExp、String。
 Array中额外的逗号情况:["Lion", , "Angel"],长度为3,[1]的值为undefiend。['home', , 'school', ],最后一个逗号省略所以长度为3。[ , 'home', , 'school'],长度为4。['home', , 'school', , ],长度为4。
 integer整数:整数可以表达为十进制、八进制、十六进制、二进制。例如:

0, 117 and -345 //十进制
015, 0001 and -0o77 //八进制
0x1123, 0x00111 and -0xF1A7 //十六进制
0b11, 0b0011 and -0b11 1234 //二进制 
浮点数:[(+|-)][digits][.digits][(E|e)[(+|-)]digits]。例如:
 3.1415926,-.123456789,-3.1E+12(3100000000000),.1e-23(1e-24)

对象:对象的属性获取值可通过“.属性”或者“[属性名]”获取。例如:

var car = { manyCars: {a: "Saab", "b": "Jeep"}, 7: "Mazda" };
console.log(car.manyCars.b); // Jeep
console.log(car[7]); // Mazda

对象属性:属性名可以是任意字符串或者空字符串,无效的名字可通过引号包含起来。复杂的名字不能通过.获取,但可以通过[]获取。例如:

var unusualPropertyNames = {
"": "An empty string",
"!": "Bang!"
}
console.log(unusualPropertyNames.""); // SyntaxError: Unexpected string
console.log(unusualPropertyNames[""]); // An empty string
console.log(unusualPropertyNames.!); // SyntaxError: Unexpected token !
console.log(unusualPropertyNames["!"]); // Bang!

转意字符:下面的字符串输出结果包含了双引号,因为使用了转意符号“\””。

var quote = "He read \"The Cremation of Sam McGee\" by R.W. Service.";
console.log(quote);
//输出:He read "The Cremation of Sam McGee" by R.W. Service.1。

字符串换行法:直接在字符串行结束时添加“\”,如下代码所示:

var str = "this string \
is broken \
across multiple\
lines."
console.log(str); // this string is broken across multiplelines.

No3.控制流和错误处理
 1.块表达式
 作用:块表达式一般用于控制流,像if、for、while。下面的代码中{x++;}就是一个块声明。

while (x < 10) {
x++;
}

ES6之前没有块域范围:在ES6之前,在block中定义的变量实际是包含在方法或者全局中,变量的影响超出了块作用域的范围。例如下面的代码最终执行结果为2,因为block中声明的变量作用于方法。

var x = 1;
{
var x = 2;
}
console.log(x); // outputs 2

ES6之后有块域范围:在ES6中,我们可以把块域声明var改成let,让变量只作用域block范围。 

2.逻辑判断
判断为false的特殊值:false、undefined、null、0、NaN、”"。
 简单boolean和对象Boolean类型:简单boolean类型的false和true与对象Boolean类型的false和true是有区别,两者是不相等的。如下面的例子:

var b = new Boolean(false);
if (b) // 返回true
if (b == true) // 返回false

No4.异常处理
 1.异常类型
 抛出异常语法:抛异常可以是任意类型。如下所示。

throw "Error2"; // 字符串类型
throw 42; // 数字类型
throw true; // 布尔类型
throw {toString: function() { return "I'm an object!"; } }; //对象类型

自定义异常:

// 创建一个对象类型UserException
function UserException(message) {
this.message = message;
this.name = "UserException";
}

//重写toString方法,在抛出异常时能直接获取有用信息
UserException.prototype.toString = function() {
return this.name + ': "' + this.message + '"';
}

// 创建一个对象实体并抛出它
throw new UserException("Value too high");

2.语法
关键字:使用try{}catch(e){}finally{}语法,和C#语法相似。 
finally返回值:如果finaly添加了return 语句,则不管整个try.catch返回什么,返回值都是finally的return。如下所示:

function f() {
  try {
    console.log(0);
    throw "bogus";
  } catch(e) {
    console.log(1);
    return true; // 返回语句被暂停,直到finally执行完成
    console.log(2); // 不会执行的代码
  } finally {
    console.log(3);
    return false; //覆盖try.catch的返回
    console.log(4); //不会执行的代码
  }
  // "return false" is executed now 
  console.log(5); // not reachable
}
f(); // 输出 0, 1, 3; 返回 false

finally吞并异常:如果finally有return并且catch中有throw异常。throw的异常不会被捕获,因为已经被finally的return覆盖了。如下代码所示:

function f() {
  try {
    throw "bogus";
  } catch(e) {
    console.log('caught inner "bogus"');
    throw e; // throw语句被暂停,直到finally执行完成
  } finally {
    return false; // 覆盖try.catch中的throw语句
  }
  // 已经执行了"return false"
}

try {
  f();
} catch(e) {
  //这里不会被执行,因为catch中的throw已经被finally中的return语句覆盖了
  console.log('caught outer "bogus"');
}
// 输出
// caught inner "bogus"

系统Error对象:我们可以直接使用Error{name, message}对象,例如:throw (new Error(‘The message'));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
prototype 的说明 js类
Sep 07 Javascript
JS对外部文件的加载及对IFRMAME的加载的实现,当加载完成后,指定指向方法(方法回调)
Jul 04 Javascript
关于jQuery object and DOM element
Apr 15 Javascript
jQuery获得页面元素的绝对/相对位置即绝对X,Y坐标
Mar 06 Javascript
常见的原始JS选择器使用方法总结
Apr 09 Javascript
JavaScript学习笔记之定时器
Jan 22 Javascript
JavaScript实现汉字转换为拼音的库文件示例
Dec 22 Javascript
JS实现点击生成UUID的方法完整实例【基于jQuery】
Jun 12 jQuery
初学vue出现空格警告的原因及其解决方案
Oct 31 Javascript
layui写后台表格思路和赋值用法详解
Nov 14 Javascript
微信小程序实现搜索功能
Mar 10 Javascript
Vue实现手机计算器
Aug 17 Javascript
Js 获取、判断浏览器版本信息的简单方法
Aug 08 #Javascript
基于BootStrap实现局部刷新分页实例代码
Aug 08 #Javascript
js智能获取浏览器版本UA信息的方法
Aug 08 #Javascript
jQuery.ajax 跨域请求webapi设置headers的解决方案
Aug 08 #Javascript
一个超简单的jQuery回调函数例子(分享)
Aug 08 #Javascript
Bootstrap Table服务器分页与在线编辑应用总结
Aug 08 #Javascript
使用jQuery5分钟快速搞定双色表格的简单实例
Aug 08 #Javascript
You might like
PHP+DBM的同学录程序(2)
2006/10/09 PHP
针对初学PHP者的疑难问答(2)
2006/10/09 PHP
PHP简单实现“相关文章推荐”功能的方法
2014/07/19 PHP
PHP读取word文档的方法分析【基于COM组件】
2017/08/01 PHP
PHP通过文件路径获取文件名的实例代码
2018/10/14 PHP
php服务器的系统详解
2019/10/12 PHP
javascript之解决IE下不渲染的bug
2007/06/29 Javascript
JavaScript 语法集锦 脚本之家基础推荐
2009/11/15 Javascript
javascript对select标签的控制(option选项/select)
2013/01/31 Javascript
浅析jquery与checkbox的checked属性的问题
2016/04/27 Javascript
es6的数字处理的方法(5个)
2017/03/16 Javascript
使用 Node.js 实现图片的动态裁切及算法实例代码详解
2018/09/29 Javascript
vue表单验证你真的会了吗?vue表单验证(form)validate
2019/04/07 Javascript
简单了解three.js 着色器材质
2020/08/03 Javascript
[42:20]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python简单实现子网掩码转换的方法
2016/04/13 Python
Python简单实现两个任意字符串乘积的方法示例
2018/04/12 Python
Python实现求解一元二次方程的方法示例
2018/06/20 Python
Python实现识别图片内容的方法分析
2018/07/11 Python
python将list转为matrix的方法
2018/12/12 Python
对YOLOv3模型调用时候的python接口详解
2019/08/26 Python
Python 使用多属性来进行排序
2019/09/01 Python
解决tensorflow添加ptb库的问题
2020/02/10 Python
解决pytorch 的state_dict()拷贝问题
2021/03/03 Python
css3圆角边框和边框阴影示例
2014/05/05 HTML / CSS
韩国三星旗下的一家超市连锁店:Home Plus
2016/07/30 全球购物
Answear匈牙利:来自全球200多个知名时尚品牌
2017/04/21 全球购物
vue 中 get / delete 传递数组参数方法
2021/03/23 Vue.js
初中英语教学反思
2014/01/25 职场文书
创业女性典型材料
2014/05/02 职场文书
法人任命书范本
2014/06/04 职场文书
家具商场的活动方案
2014/08/16 职场文书
学习雷锋精神倡议书
2015/04/27 职场文书
初中班主任工作总结2015
2015/05/13 职场文书
青年文明号创建口号大全
2015/12/25 职场文书
Python四款GUI图形界面库介绍
2022/06/05 Python