1.JavaScript基于对象的语言
JavaScript和PHP不一样的地方在于:
- PHP是面向对象语言,先有类再实例化对象;
-
JavaScript是基于对象的语言,也就是说JavaScript是由很多内置的对象组成的编程语言;
JavaScript的主要内置对象
1.1数组对象
对象主要是由属性、方法组成的,所以学习数组对象就是学习数组对象提供的属性和方法;
- length属性,获得数组元素的个数
data:image/s3,"s3://crabby-images/4fb70/4fb70e3182bceccf5b90d3a50f9f90be4ec2f88b" alt=""
- concat:连接数组生成新的数组
data:image/s3,"s3://crabby-images/80860/808603a1e925b97588987df3b929b75a1b13ddec" alt=""
- join,使用指定的分隔符将数组连接成字符串
data:image/s3,"s3://crabby-images/2cdb2/2cdb201b2d4095e3a63c8c4321f4f71ba8921822" alt=""
- push、pop:分别表示向数组末尾添加元素、删除末尾的元素
data:image/s3,"s3://crabby-images/0c769/0c76945229d0de9797706500f6914cf0c66b9432" alt=""
- shift、unshift分别表示删除数组第一个元素、向数组开头添加一个元素
data:image/s3,"s3://crabby-images/73635/736352b88852b6cbeb9d8aeae97a649c771ed05c" alt=""
- reverse,颠倒数组顺序
data:image/s3,"s3://crabby-images/3b065/3b06501f1f9eae4055c844a8eca1efdec6d1cfd2" alt=""
-
slice(),截取数组元素,并将截取的部分返回
参数1:开始的索引位置
参数2:结束的索引
截取字符串
-
splice() 删除数组元素,这个方法在执行时返回的是删除的数组元素
参数1:开始的索引位置
参数2:删除的元素个数
参数3:可选的,如果有参数3,表示使用参数3代替删除的那些元素
splice方法比slice方法要强大一些
- toString(), 将数组转换为字符串,该结果的返回值是修改后的字符串
data:image/s3,"s3://crabby-images/8ad63/8ad63b755f4a108f93a4eee7ce6c7eeb9269d4c6" alt=""
1.2字符串对象
- indexOf(),获得某个字符在字符串整体中第一次出现的索引
- lastIndexOf(),获得某个字符在字符串整体中最后一次出现的索引
data:image/s3,"s3://crabby-images/8fd44/8fd448367b0b0c55e533f19b78ff762ac625e515" alt=""
- split(),根据指定的分隔符,将字符串拆分成数组
参数1:分隔符号
参数2:限制返回的结果数量
data:image/s3,"s3://crabby-images/22f57/22f57735e13adfc97c2580a0725400097b3c3117" alt=""
- replace,字符串替换
参数1:正则表达式
参数2:替换的结果
data:image/s3,"s3://crabby-images/df30d/df30d32e677f7ea277dea6e00a57e1ee743e0337" alt=""
- match()方法,用来根据正则表达式进行筛选
data:image/s3,"s3://crabby-images/d9af5/d9af5edd3a7ed171d515dcffd4e8748d4b7f73ef" alt=""
- charAt(),用来获得在指定索引位置的字符是什么?
参数:索引位置
data:image/s3,"s3://crabby-images/4953e/4953e43e38c8bf12f381fd8dca2fb0c0b8932f60" alt=""
- slice,字符串截取
参数1:开始的索引位置
参数2:结束的索引位置
data:image/s3,"s3://crabby-images/f75d8/f75d86f2d52f9ccbb7aa7edd2bd4297c528246d0" alt=""
- substr()
参数1:开始的索引位置,如果正数从0开始;如果是负数,从后面向前面数
参数2:截取的长度
data:image/s3,"s3://crabby-images/d906c/d906c68ddfb1214ed9cc8146634e1788d87d5634" alt=""
- toLowerCase(),将字符串转换成小写
toUpperCase(),将字符串转换成大写
data:image/s3,"s3://crabby-images/dae1d/dae1dc029c97a64c0151c4767cfb18825f427be8" alt=""
1.3数学对象
JavaScript给我们提供的用来进行数学计算的对象,Math
-
Math.abs(),计算一个数值的绝对值,例如 -9的绝对值就是:9
计算一个数值的绝对值
-
Math.ceil(),向上取整,进一取整
要注意负数的情况
-
Math.floor(),向下取整
data:image/s3,"s3://crabby-images/bdb9d/bdb9df23df76c4b318980ee8b5fb0cad373db8e4" alt=""
- Math.round(),四舍五入取整
data:image/s3,"s3://crabby-images/a08be/a08bef2454d7edfe5c88f87fec558e3a7d8fbbdd" alt=""
- max(),获得最大值
min(),获得最小值
data:image/s3,"s3://crabby-images/3d164/3d164531624fda202885feb617f06efb1247a2df" alt=""
- Math.pow(x,y)计算x的y次方
data:image/s3,"s3://crabby-images/e5b62/e5b62ca721b7d8a517428335194b622f8af7a521" alt=""
- Math.sqrt(),返回数值的平方根
data:image/s3,"s3://crabby-images/1be19/1be19b81a9f402cc73ad462e13c750c368191dd1" alt=""
Math.random(),返回0-1之间的小数,这是js中取随机数的一种方法
1.4日期对象
说明:日期对象是JavaScript封装的用来操作日期、时间的对象
通过new Date()获得日期对象
- getFullYear(),获得年份
getMonth(),获得当前的月份
getDate()获得当前的日期
getHours()获得当前的时间
getMinutes()获得当前的分钟
getSeconds()获得当前的秒数
data:image/s3,"s3://crabby-images/185a6/185a6dadea64376e83ed6df2bebf4de8a016fe1a" alt=""
- getDay(),获得当前是星期几?
data:image/s3,"s3://crabby-images/ae8a8/ae8a879ecc1ec85b4ae199156ae1fdaebfee6235" alt=""
- getMiliseconds()获得当前时间的毫秒部分:1000毫秒==1秒
data:image/s3,"s3://crabby-images/70595/7059544522586c7c46d699d54f5dcd8a2862b20f" alt=""
\
- getTime(),获得当前的时间戳(单位毫秒)php时间戳的单位是(秒)
- toLocaleString(),将日期对象转换成本地时间格式
data:image/s3,"s3://crabby-images/4e889/4e889dbe8909b60c73c2d3d8edbe71c9ac9ffb1f" alt=""
- 设置日期:
setFullYear(),设置年份
setMonth(),设置月份
setDate(),设置日期
获得上个月1号是星期几?
data:image/s3,"s3://crabby-images/35ae7/35ae75823a526c5c341a66176f883113ef2897a7" alt=""
getDay()返回的是0-6的数字,分别代表了0为星期日,6为星期六;
1.5正则表达式对象
这个在正则表达式,我有做详细的论述
1.6DOM对象
这个在DOM操作这章我有做详细的论述
1,7BOM对象
BOM,Browser Object Model,浏览器对象模型,独立于内容之外的,和浏览器进行交互的对象(前进、后退、地址栏、浏览器本身一些信息等)
BOM这个浏览器对象模型给我提供了如下子对象和浏览器进行交互:
- location对象,操作浏览器地址栏
data:image/s3,"s3://crabby-images/e65b0/e65b0de7432a5048ff05f1544bae64313fb430e8" alt=""
-
history对象,操作浏览器历史记录(前进、后退、刷新)
history.go(-1),后退1步
history.go(-2),表示后退2步
....
history.go(1),前进1步
history.go(0):刷新页面
....
history.forward():前进一步
history.back():后退1步 -
screen对象,获得屏幕分辨率
data:image/s3,"s3://crabby-images/a6771/a6771688c1bd02475ab6ac31505b406dde31026d" alt=""
- navigator对象,获得浏览器本身的信息
appName: 返回浏览器内核名称
appVersion: 返回浏览器和平台的版本信息
platform: 返回运行浏览器的操作系统平台
userAgent: 返回由客户机发送服务器的 user-agent 头部的值
data:image/s3,"s3://crabby-images/5d074/5d074ec20c5f9c09840e504fd9117e9bc48a89c5" alt=""
1.8 Window对象
window,指的是浏览器窗口,也是javascript的一个顶层对象,该对象包括DOM
、BOM,也就是说:DOM对象、BOM对象都是window的子对象
data:image/s3,"s3://crabby-images/b90a6/b90a67efcd784861a6218a7372c9047cce45d85e" alt=""
除了DOM、BOM之外,window对象还提供了一些方法供我们使用:
-
alert():弹出警告框
-
confirm(),弹出一个确认框
参数:弹出框显示的内容
返回布尔值,点击确定返回true,点击取消返回false
data:image/s3,"s3://crabby-images/0cc57/0cc576e3b6a9ff3e5597feb3f3afc566330258fb" alt=""
如果点击确定,则返回true,如果点击取消则返回false
- prompt(),弹出一个输入框
//参数1:在输入框提示的信息
//参数2:默认值
//返回值:点击确定获得输入框的内容;点击取消返回null
data:image/s3,"s3://crabby-images/83d66/83d66efb2394c8fcbdf8b17262bab9107aab675e" alt=""
- setInterval,设置计时器(定时炸弹),每间隔指定的时间就执行一次
- clearInterval,清除计时器
//开启一个计时器,每间隔1秒执行一次
//参数1:执行的函数体
//参数2:间隔的时间,单位是毫秒
//返回值:id,将来删除这个计时器的标记
- setTimeout,设置延迟执行,延迟指定的时间执行一次
- clearTimeout,清除延迟执行
<h1>复习部分</h1>
<h1>1.什么是变量的声明前置?什么是函数的声明前置?</h1>
所谓变量提升是指javaScript引擎的一种工作方式,先解析代码,获取所有声明的变量,之后再一行一行的运行,因此我们在js中先声明变量,再给变量赋值,其运行机制是先把变量的声明语句提升到代码的头部,相当于在代码的预执行阶段,变量就已经在头部执行了,并赋值为undefined;
而函数声明前置,则是在函数预执行阶段,将函数声明语句提到代码头部执行,那么该函数实际在代码正式执行之前就已经声明过了,因此在js中,调用函数语句可以写在函数声明语句的前面.
<h1>2.函数声明和函数表达式有什么区别?</h1>
<h3>首先明白怎么定义函数?</h3>
定义函数的方法有三种:
- 1.函数声明(Function Declaration)
- 2.函数表达式(Function Expression)
- new function 构造函数,这种方式不推荐使用;
函数声明语法格式如下:
function functionName(){ statement; } printName();
函数声明的重要特征之一是<b>函数声明提升</b>,意思是执行代码之前会读取函数声明,这也就意味着函数声明可以放在调用它的语句后面,如下:
sayHi(); function sayHi(){ alert("Hi"); }
结果是返回弹窗Hi.
函数表达式语法格式如下:
var printName = function(){ console.log('Byron'); };
函数表达式的形式看起来似乎是一个常规的变量赋值语句,即将函数作为一个值赋给变量,同样的也能够将函数作为其他函数的值返回.
<h3>那么函数表达式与函数声明有什么区别了?</h3>
- 函数表达式可以没有函数名,这种情况创建的函数称之为匿名函数;函数声明必须要有函数名,我们试试看
data:image/s3,"s3://crabby-images/8eed2/8eed20430e4010ea5a0052548ed13cb09d0ffbdb" alt=""
data:image/s3,"s3://crabby-images/35d67/35d67b74516f5fa63225d66f6b18ecc7c6b5af40" alt=""
声明函数时,不设置函数名会提示语法错误;
-
函数表达式与函数声明的最重要区别就在于函数声明会提升
因为函数声明会提升,在执行代码之前会读取函数声明,想当于在代码执行之前,函数声明已经执行过了,而函数表达式则是代码执行到函数表达式之后再进行执行.
<h1>3.arguments 是什么?</h1>
在函数内部可以使用arguments对象获取到该函数的所有传入参数:
<h1>4.函数的"重载"怎样实现?</h1>
在JavaScript中没有函数重载的概念,函数通过名字确定唯一性,参数不同也被认为是相同的函数,后面的覆盖前面的.
可以在函数体针对不同的参数调用执行相应的逻辑。如下所示:
`function printPeopleInfo(name, age, sex){
if(name){
console.log(name);
}
if(age){
console.log(age);
}
if(sex){
console.log(sex);
}
}
printPeopleInfo('Byron', 26);
printPeopleInfo('Byron', 26, 'male');`
<h1>5.立即执行函数表达式是什么?有什么作用</h1>
立即执行函数表达式就是(function(){})()
使用立即执行函数表达式的作用是隔离变量,防止全局变量被污染;
<h1>6.求n!,用递归来实现</h1>
data:image/s3,"s3://crabby-images/51f2b/51f2ba717097a1f93e5f3795fa3dccc90df5636b" alt=""
data:image/s3,"s3://crabby-images/04d93/04d938c09ea0106bf8fde005da45c0393a55be98" alt=""
<h1>7.以下代码输出什么?</h1>
data:image/s3,"s3://crabby-images/65b59/65b596ff14aafd1011716f765bf5e162a534a546" alt=""
输出结果应该是:
//name:饥人谷; age:2; sex:男;name:valley;
//name:小谷; age:3; sex: undefined;name:valley;
//name:男;age: undefined; sex: undefined; name: valley;
<h1>8.写一个函数,返回参数的平方和?</h1>
data:image/s3,"s3://crabby-images/be029/be0299b15755a88cf89f7613541717bc9b30774b" alt=""
平方和函数如下:
data:image/s3,"s3://crabby-images/166e1/166e1b94f4a202ef5a5d649fa8b4272df6583115" alt=""
<h1>9. 如下代码的输出?为什么?</h1>
data:image/s3,"s3://crabby-images/0641d/0641d3cba9e43e1df7c9b7a55fe35ec91d94ee47" alt=""
- 应该是输出undefined 以及报错,原因在于:变量提升,a由于提到代码头部,被赋值undefined,因此输出undefined,而b未定义,因此会报错;
data:image/s3,"s3://crabby-images/2fa74/2fa7462bd22dbab60469d3572e786ccfd0fe81d4" alt=""
<h1>10. 如下代码的输出?为什么</h1>
data:image/s3,"s3://crabby-images/ec04a/ec04a35c5be3fb7f5c2174271efa0f3574b066bd" alt=""
- 由于函数声明提升,而函数表达式不会提升,因此在代码预执行阶段,函数声明已经提升至代码头部,接下来执行阶段,sayName('world')输出helloworld,而到了执行sayAge(10)阶段,由于函数表达式相当于还未声明,因此会报错,这个函数尚不存在!
data:image/s3,"s3://crabby-images/4a5d9/4a5d9c4c2f1e74dcb2b49007a94001001629c95c" alt=""
<h1>11. 如下代码输出什么? 写出作用域链查找过程伪代码</h1>
data:image/s3,"s3://crabby-images/a965e/a965e476e7044a2212c68292e1819328141e407d" alt=""
1.全局作用域:
globalContext = {
AO: {
x: 10;
foo: function;
bar: function;
}
Scope: null;
}
//声明foo时,得到scope属性
foo.[[scope]] = globalContext.AO;
//声明bar时,得到scope属性
bar[[scope]] = globalContext.AO;
2.当调用bar()时,进入bar的执行上下文
barContext = {
AO:{
x: 30;
}
Scope: bar.[[scope]]// bar[[scope]] = globalContext.AO
}
3.调用foo(),先从bar执行上下文的活动变量(AO)中找,找不到再从bar.[[scope]]中找,找到后进行调用
4.调用foo(),进入foo的执行上下文
fooContext{
AO{
null
}
Scope: foo.[[scope]]//foo.[[scope]]=globalContext.AO;
}
5.在globaContext.AO中,x:10;因此调用foo()输出为10;
6.整体调用bar[],输出结果为10;
data:image/s3,"s3://crabby-images/3597e/3597e5b10d8691512288baa7e6cb89ceb5f72ebd" alt=""
结果于预期一致,输出为10;
<h1>12. 如下代码输出什么? 写出作用域链查找过程伪代码</h1>
data:image/s3,"s3://crabby-images/d4d09/d4d0930ad839f1929a13372b449f3e3834020638" alt=""
1.全局作用域
globalContext{
AO{
x:10;
bar: function;
}
Scope: null
}
//声明函数bar得到Scope属性
bar[[scope]] = globalContext.AO;
2.执行bar(),进入bar的执行上下文
bar.Context{
AO{
x: 30;
foo : function;
}
Scope: bar[[scope]]//bar[[scope]]=globalContext.AO
}
//声明函数foo得到其Scope属性
foo[[scope]] = bar.context.AO;
3.执行bar()时,调用foo(),这时进入foo的执行上下文
foo.Context{
AO{
null;
}
Scope: foo.[[scope]];//foo.[[scope]]=bar.context.AO
}
4.执行console.log(x),x从当前foo.Context.AO中查找,无果,从foo.[[scope]]中查找,实质上就是从bar.Context.AO中查找,查到x=30,因此输出结果应该为30;
data:image/s3,"s3://crabby-images/baa5c/baa5c48fedafd2aaa175f6a4d7a7937d1b145236" alt=""
如同预期输出结果为30;
<h1>13. 以下代码输出什么? 写出作用域链的查找过程伪代码</h1>
data:image/s3,"s3://crabby-images/957e3/957e3d15aaaf482a331895d976bde5124b13fbe8" alt=""
1.全局作用域
globalContext{
AO{
x :10;
bar : function;
}
Scope: null;
}
//声明bar函数时,bar函数得到Scope属性
bar.[[scope]] = globalContext.AO;
2.执行bar(),进入bar的执行上下文
bar.Context{
AO{
x: 30;
立即执行函数(匿名函数): function;
}
Scope: bar.[[scope]] //bar.Context=globalCotext.AO;
}
声明立即函数时,立即执行函数得到属性Scope
function.[[scope]] = bar.Context.AO;
3.调用立即执行函数,进入其执行上下文
function.Context{
AO{
null;
}
Scope: function.[[scope]];
}
4.执行console.log(x),x从当前执行上下文中查找,先查function.Context.AO,无果,之后从function.[[scope]]中查找,function.[[scope]]=bar.Context.AO, 从中查找查x=30;
输出 30;
<h1>14. 以下代码输出什么? 写出作用域链查找过程伪代码</h1>
data:image/s3,"s3://crabby-images/f2128/f212865d6bc767ecc49baccb41d5597159877e8a" alt=""
1.全局作用域
globalContext{
AO{
a: 1;
fn : function;
fn3 : function;
}
Scope: null;
}
//声明函数fn时,得到其Scope属性
fn.[[scope]] = globalContext.AO;
//声明函数fn3时,得到其Scope属性
fn3.[[scope]] = globalContext.AO;
2.调用fn(),进入fn的执行上下文
fnContext{
AO{
a:5;
a:6;
fn2: function;
}
Scope: fn.[[scope]] //fn.[[scope]] = globalContext.AO
}
//声明fn2,得到其属性Scope
fn2.[[scope]] = fnContext.AO;
3.执行第一个console.log(a),输出为undefined;
4.赋值操作,a=5;
5.执行第二个console.log(a),输出5;
6.a++,a =6;
7.调用fn3(),进入fn3的执行上下文
fn3Context{
AO{
null
}
Scope: fn3.[[scope]];//fn3.[[scope]]=globalContext.AO;
}
8.执行fn3内部console.log(a),a搜寻当前执行上下文,从fn3,[[scope]]中搜寻,a=1;输出1;之后执行赋值操作,a=200;调用fn3完毕
9.调用fn2(),进入fn2的执行上下文
fn2Context{
AO{
null
}
Scope: fn2.[[scope]]//fn2.[[scope]] = fnContext.AO;
}
10.执行fn2内部的console.log(a),a从当前执行上下文中搜寻,从fn2.[[scope]]中搜寻得a=6,输出5;之后赋值操作,a=20;调用fn2结束
11.执行console.log(a),输出20;调用fn()结束;
12.执行console.log(a),此时全局变量a为200;
总的输出: undefined,5,1,6,20,200;
网友评论