0

0

最全JavaScript知识点总结

小云云

小云云

发布时间:2018-01-17 11:33:12

|

4691人浏览过

|

来源于php中文网

原创

本文主要和大家分享最全javascript知识点总结 ,希望能帮助到大家。

1.js面向对象的理解

<span style="font-size: 14px;">面向对象的三大特点:继承、封装、多态<br/>1、js中通过prototype实现原型继承<br/>2、js对象可以通过对象冒充,实现多重继承,<br/>3、object类是所有js类的基类<br/>4、通过function对对象进行封装<br/>5、通过使用arguments实现参数重载<br/>6、es6语法糖可以直接定义类class,继承对象extends<br/></span>

2.js数据类型

<span style="font-size: 14px;">1.基本数据类型:<br/><br/>undefined:代表一切未知的事物,啥都没有,无法想象,代码也就更无法去处理了。<br/>          注意:typeof(undefined) 返回也是 undefined。可以将undefined赋值给任何变量或属性,但并不意味了清除了该变量,反而会因此多了一个属性。<br/>    <br/>null:有那么一个概念,但没有东西。无中似有,有中还无。虽难以想象,但已经可以用代码来处理了。<br/>     注意:typeof(null)返回object,但null并非object,具有null值的变量也并非object。<br/>    <br/>boolean:是就是,非就非,没有疑义。对就对,错就错,绝对明确。既能被代码处理,也可以控制代码的流程。<br/><br/>number:线性的事物,大小和次序分明,多而不乱。便于代码进行批量处理,也控制代码的迭代和循环等。<br/>       注意:typeof(nan)和typeof(infinity)都返回number 。nan参与任何数值计算的结构都是nan,<br/>       而且 nan != nan 。infinity / infinity = nan 。<br/>    <br/>string:面向人类的理性事物,而不是机器信号。人机信息沟通,代码据此理解人的意图等等,都靠它了。<br/><br/>2.引用数据类型:object、array、function<br/></span>

3.js判断数据类型的几种方法

<span style="font-size: 14px;">1、typeof<br/>2、prototype<br/>3、instanceof<br/>4、constructor<br/>5、object.prototype.tostring.call(a)<br/>注意 : typeof null === object<br/></span>

4.object对象的认知

<span style="font-size: 14px;">js中所有的对象都继承自object<br/>创建一个新对象: <br/><br/>var person = new object();<br/>person.name = "狼狼的蓝胖子";<br/>person.age = 25;<br/><br/>constructor属性是保存当前对象的构造函数,前面的例子中,constructor保存的就是object方法。<br/>hasownproperty方法接收一个字符串参数,该参数表示属性名称,用来判断该属性是否在当前对象实例中,而不是在对象的原型链中。<br/>isprototype方法接收一个对象,用来判断当前对象是否在传入的参数对象的原型链上<br/></span>

4.array数据的一些方法用法

<span style="font-size: 14px;">concat() 连接两个或更多数组<br/>splice(index,len,[item]) 删除元素,并向数组添加一个新元素。<br/>slice() 从某个已有的数组返回选定的元素<br/>join() 把数组的所有元素放入一个字符串,元素通过指定的分隔符进行分割<br/>push() 在数组后添加元素,并返回新的长度<br/>unshift() 在数组最前添加元素<br/>pop() 删除数组最后一个元素并返回该元素的值<br/>reverse() 颠倒数组中元素的顺序<br/>shift() 删除并返回数组中第一个元素<br/>sort() 对数组元素进行排序<br/>tosource() 返回该对象的源代码<br/>tostring()  把数组转换为字符串并返回结果<br/>tolocalestring() 把数组转换为本地数组,并返回结果<br/>valueof() 返回对象的原始值<br/></span>

5.function函数的理解

<span style="font-size: 14px;">两种自定义函数的方法 1.function fnname(){}  2. var fnname=function(){}<br/>函数的返回值:1.当函数无明确返回值时,函数返回undefined。2.有返回值返回。<br/>函数的参数列表是可变的,数据类型也是任意数据类型,js中有一个变量,argument可以访问所有传到函数内部的参数。<br/>js支持创建动态函数,动态函数必须用function对象来定义。<br/>创建动态函数的基本格式:<br/>var 变量名 = new function("参数1","参数2","参数n","执行语句");<br/>var add = new function("x", "y", "return(x+y)");<br/>javascript不支持函数的重载。如果两个方法名字一样,即使参数个数不一样,那么后面定义的就会覆盖前面定义,调用方法时永远是调用后定义的那个。<br/></span>

6.ajax请求的原理

<span style="font-size: 14px;">通过xmlhttprequest对象来向服务器发送异步请求,从服务器获取数据。然后用javascript来操作dom而更新页面。<br/>xmlhttprequest是ajax的核心机制,它是ie5中首先引入的,是一种支持异步请求的技术。简单的说,也就是javascript可以及时的向服务器提出请求并及时响应。而不阻塞用    户。达到无刷新效果。由事件触发,创建一个xmlhttprequest对象,把http方法 (post/get)和目标url以及请求返回后的回调函数设置到xmlhttprequest对象,通过        xmlhttprequest向服务器发送请求,请求发送后继续响应用户的界面交互,只有等到请求真正从服务器返回的时候才调用callback()函数,对响应数据进行处理。<br/>function ajax(){<br/>if(window.xmlhttprequest){<br/>    var xhr =new xmlhttprequest();<br/>    }else{<br/>        var xhr=new activexobject(‘microsoft.xmlhttp’);<br/>    }<br/>    xhr.onreadystatechange=function(){<br/>    if(xhr.readstate==4){}<br/>    }<br/>}<br/></span>

7.js闭包(closure)

<span style="font-size: 14px;">闭包就是能够读取其他函数内部变量的函数。由于在javascript语言中,只有函数的内部的子函数才能读取局部变量,因此可以把闭包简单理解成“定义在函数内部的函数”。所以    在本质上,闭包就是讲函数内部和函数外部链接起来的一座桥梁。<br/>闭包的用途:1.获取函数内部的局部变量。2.让这些变量始终保持在内存中。<br/>注意:1.由于闭包会使得函数中的变量一直保存在内存中,所以不能滥用闭包,容易导致内存泄漏,影响网页性能,解决方法就是在退出函数之前,将不再使用的变量全部删除        (delete);2闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(public method),把内部变量当        作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。<br/></span>

8.this的工作原理

<span style="font-size: 14px;">this总是指向一个对象,具体是运行时基于函数的执行环境动态绑定的,而非函数被声明时的环境。<br/>普通函数调用时,一般指向window对象;<br/>对象方法调用时,指向该对象;<br/>如果对象方法里有局部方法,里面的this会指向window对象;<br/>在es5模式下,this指向window的都会变成undefined;<br/>apply,call时,动态改变this<br/></span>

9.js中继承的几种方法

<span style="font-size: 14px;">prototype   原型继承<br/>call()<br/>apply()<br/>//模拟extend<br/> var extend=function(target,source){<br/>     for(property in source)<br/>     {<br/>         if(target.hasownproperty(property))<br/>         {<br/>             target[property]=source[property];<br/>         }else{<br/>             target.property=source[property];<br/>         }<br/>     }<br/>     return target;<br/> }<br/></span>

10.原型链

<span style="font-size: 14px;">首先要理解原型<br/>每个JS对象都有一个prototype原型属性,指向该对象继承的原型。<br/>原型对象上有一个 constructor 属性,该属性指向的就是构造函数。<br/>而实例对象上有一个 __proto__  属性,该属性也指向原型对象,并且该属性不是标准属性,不可以用在编程中,该属性用于浏览器内部使用。<br/><br/>原型链:其实就是有限的实例对象和原型之间组成有限链,就是用来实现共享属性和继承的。<br/></span>

相关推荐:

JavaScript知识点系统总结

一些容易犯错的JavaScript知识点整理

AI Note
AI Note

AI Note 助手,像贴心女仆一样助力你的笔记!智能总结内容,精确划重点,提供专业建议,让学习与工作更高效。让你的笔记更清晰、有条理,知识尽在眼前!

下载

你必须知道的Javascript知识点之"字面量和对应类型"说明介绍_javascript技巧

立即学习Java免费学习笔记(深入)”;

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

307

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

183

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

29

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

103

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

54

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

17

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

764

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

92

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.1万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号