一.总括

基础知识:

1.变量

2.原型和原型链

3.作用域和闭包

4.异步和单线程

JS的API:

1.BOM,DOM操作

2.事件绑定

3.Ajax

4.JSOP

5.存储

二.基础知识

2.1知识点(变量)

1)变量类型

  • 值类型(基本类型)VS引用类型(对象、数组、函数)
  • typeof运算符

2)变量计算---强制类型转换

  • 字符串拼接
  • ==和===运算符
  • if语句
  • 逻辑运算

问题:

①何时用==和===:if(obj.a==null)相当于if(obj.a===null || obj.a===undefined)其他时候用===

②JS中的内置函数(数据封装类对象):Object、Array、Boolean、Number、String、Function、Date、RegExp、Error

③JS变量按储存方式分为哪些类型:基本类型和引用类型(变量a赋给变量b,改变a,b会怎样)

④什么是JSON:JSON是一个JS对象,它有两个常用API(stringify和parse),同时也是一种数据格式

⑤typeof运算符:null、[ ]、{ }是object;函数是function;其它该是什么是什么

⑥if(xxx):xxx表达式为0、NaN、null、'  '、undefined、false时if语句为错

2.2知识点(原型和原型链)

1)构造函数

function Foo(a,b){
this.a = a;
this.b = b;
//默认返回this
}
//可以有很多实例,括号内可传参
var f1 = new Foo( );
var f2 = new Foo( );

2)构造函数扩展

var a = { } 相当于 var a = new Object( )
var a = [ ] 相当于 var a = new Array( )
function Foo( ){ } 相当于 var Foo = new Function( )

3)原型规则

  • 所有引用类型,除了null,(即数组、对象、函数)都有一个_proto_属性(隐式原型),属性值是一个普通的对象。
  • 所有函数都有一个prototype属性(显式原型),属性值也是一个普通的对象。
  • 所有引用类型,除了null,(即数组、对象、函数)_proto_属性值指向它的构造函数的prototype属性。
obj._proto_ === Object.prototype
  • 要找一个对象的某个属性时,若对象本身没有此属性就去它的_proto_(它构造函数的prototype)中找。

问题:

①判断一个变量是数组类型:instanceof、isArray( )

②写一个原型继承例子

③描述new一个对象的过程:创建新对象-->this指向新对象-->执行代码(对this赋值)-->返回this

④zepto(或者其他框架中)如何使用原型链

2.3知识点(闭包和作用域)

1)执行上下文

  • 范围:一段<script>或者一个函数
  • 全局作用域(一段<script>)
  • 函数作用域(函数)

2)this

  • this要在执行时才能确认值,定义时无法确认值。
  • this指向:
①作为构造函数执行:
定义this空对象-->对this赋值-->返回this ②作为对象属性执行:
var obj = {
name : 'a',
personName : function( ){
console.log(this.name)
}
} //obj.personName( )指向obj ③作为普通函数执行:
function fn( ){
console.log(this)
}//this指向window ④call,apply,bind改变this指向

3)作用域(没有块作用域,有全局作用域和函数作用域。注:ES6有块作用域)

4)作用域链

  • 自由变量:当前作用域没定义的变量
  • 链:自由变量可以一直往父作用域(定义时的父作用域,不是执行时的作用域)

5)闭包

  • 函数作为返回值
  • 函数作为参数来传递

问题:

①变量提升的理解

②写一个闭包例子及实际开发中的闭包应用

③理解作用域:自由变量、作用域链、闭包两个场景

2.4知识点(异步和单线程)

1)什么是异步

  • 异步非阻塞(setTimeout),同步阻塞(alert)
  • 需要异步:可能发生等待的情况,而等待过程不能阻塞程序运行

2)前端需要异步的场景

  • 定时任务:setTimeout、setInterval
  • 网络请求:ajax请求、动态<img>加载
  • 事件绑定

3)异步和单线程

  • 执行setTimeout后,传入它的函数会被暂存,不立即执行(单线程特点,不同时做两件事)
  • 待所有程序执行完,处于空闲状态时,立马看有没有暂存起来的要执行
  • 发现暂存起来的setTimeout中的函数,立即过来执行

2.5知识点(其他)

1)日期

var date = new Date( );
date.getTime( );//毫秒
date.getFullYear( );//年
date.getMonth( );//月
date.getDate( );//日
date.getHours( );//时
date.getMinutes( );//分
date.getSeconds( );//秒

2)Math

Math.random( )//获取随机数

3)数组API

forEach、every、some、sort、map、filter

4)对象API

for(item in obj){ }

问题:

①获取xxxx-xx-xx格式的日期

②获取长度一致字符串格式 随机数

③写一个能遍历对象和数组通用的forEach函数

这里只粗略列出知识点,不作详细介绍。

JavaScript重点知识(一)的更多相关文章

  1. AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解

    AST抽象语法树——最基础的javascript重点知识,99%的人根本不了解 javascriptvue-clicommonjswebpackast  阅读约 27 分钟 抽象语法树(AST),是一 ...

  2. JavaScript重点知识(二)

    三.JS的API 3.1知识点(DOM) 1)DOM本质 将html结构化成浏览器和JS可识别可操作的东西 2)变量计算---强制类型转换 获取DOM节点 Attribute(对html标签属性的修改 ...

  3. AJAX重点知识的心得体会

    下面就为大家带来一篇 AJAX重点知识的心得体会.学习还是有点帮助的,给大家做个参考吧. AJAX是什么? 是Asynchronous Javascript And XML的首字母的缩写, 它不是一门 ...

  4. Javascript基础知识总结一

    Javascript基础知识总结一 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...

  5. 【转载】STL"源码"剖析-重点知识总结

    原文:STL"源码"剖析-重点知识总结 STL是C++重要的组件之一,大学时看过<STL源码剖析>这本书,这几天复习了一下,总结出以下LZ认为比较重要的知识点,内容有点 ...

  6. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  7. 学习javascript基础知识系列第三节 - ()()用法

    总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...

  8. javascript常用知识点集

    javascript常用知识点集 目录结构 一.jquery源码中常见知识点 二.javascript中原型链常见的知识点 三.常用的方法集知识点 一.jquery源码中常见的知识点 1.string ...

  9. 七个开法者经常忽略或误用的JavaScript基本知识

    七个开法者经常忽略或误用的JavaScript基本知识 翻译自 http://tech.pro/tutorial/1453/7-javascript-basics-many-developers-ar ...

随机推荐

  1. AtCoder Beginner Contest 066 B - ss

    题目链接:http://abc066.contest.atcoder.jp/tasks/abc066_b Time limit : 2sec / Memory limit : 256MB Score ...

  2. 模板(Template)系统

    一.常用语法 官方文档 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 1.1变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点(.)在模板 ...

  3. Mysql初级第二天(wangyun)

    SQL 1.LIKE 操作符 SELECT 列名称 FROM 表名称 WHERE 列 LIKE 值('N%'/'%N%'/'%N','N_') SELECT 列名称 FROM 表名称 WHERE 列 ...

  4. mysql union 和 left join 结合查询用法

    union 和 left join 结合查询用法 SELECT u.nickname,z.group_comming_type,z.id,z.user_id,z.title,z.create_time ...

  5. Fiddler(三)Fiddler 报错creation of the root certificate was not successful

    打开CMD,找到Fiddler所在目录,我这里是把汉化版的解压在了桌面,所以通过CMD进入桌面下的Fiddler文件夹. 执行命令 makecert.exe -r -ss my -n -h -cy a ...

  6. 探索RequestBody报com.alibaba.fastjson.JSONObject cannot be cast to xxx

    今天使用RequestBody接受前端传过来的参数,以前接受字符串数组非常成功,这次把形参改成了List<User>,原本以为顺利接受参数并映射成User的list结构,结果竟然在我取us ...

  7. Spring Boot 2 (三):Spring Boot 2 相关开源软件

    Spring Boot 2 (三):Spring Boot 2 相关开源软件 一.awesome-spring-boot Spring Boot 中文索引,这是一个专门收集 Spring Boot 相 ...

  8. dubbo环境搭建与tomcat集成、DEMO示例、常见问题(最完整版本、带管理控制台、监控中心、zookeeper)

    以windows为例,linux基本相同,开发环境一般linux,个人环境一般windows(如果不开额外vm的话). 示例以dubbo官方自带demo为例子,进行整合和稍加修改测试. 0.dubbo ...

  9. 【题解】Luogu P3203 [HNOI2010]弹飞绵羊

    原题传送门 这题用Link-Cut-Tree解决,Link-Cut-Tree详解 预处理:从一个点弹到另一个点就在lct里从\(i\)连边到\(i+k_i\),如果绵羊被弹飞了就从\(i\)连边到\( ...

  10. opencv学习之路(18)、霍夫变换

    一.简介 在图像处理和计算机视觉领域中,如何从当前的图像中提取所需要的特征信息是图像识别的关键所在.在许多应用场合中需要快速准确地检测出直线或者圆.其中一种非常有效的解决问题的方法是霍夫(Hough) ...