DOM特殊元素获取

document.documentElement //HTML标签

document.head //head标签

document.title //title标签

document.body //body标签

typeof 的那些坑

typeof null 返回Object, 然而null是基本类型值而不是引用类型值,null == null 是成立的。

typeof NaN 返回number,NaN是一个自身不等于自身的数值类型。

typeof Symbol 返回function。

平稳退化和逐渐增强

平稳退化:可让访问者的浏览器在不支持JS的情况下仍能顺利地浏览网站。

逐渐增强:用一些额外的信息层去包裹原始数据,用css,js去包裹html结构。

按照逐渐增强的原则创建出来的网页几乎都符合平稳退化原则。

性能考虑

  • 尽量减少访问DOM和标记。查询DOM中的某个元素都会搜索整个DOM树,因此最好将搜索结果保存在变量中后续操作使用。从源头上减少html元素节点以减小DOM树规模也是一点。
  • 合并和放置脚本。合并多个脚本为一的原因可以减少加载页面时的请求数量,这是性能优化时首先需要考虑的。合理放置脚本(把script标签置于/body标记前,可先让其他文件并行加载,并在加载JS脚本时window对象的onload事件依然可以执行对文档进行各种操作)。
  • 压缩脚本。删除空格注释,用短小的变量函数名替代,以达到精简脚本大小的目的。

var,let 和 const的区别

var 属于ES5的关键词,有变量提升作用,不存在块级作用域,因此容易出现被添加到在外部环境的问题。可以重复声明。在全局环境下声明一个变量会成为顶层对象的属性。

let和const属于ES6的关键词,无变量提升,存在TDZ,存在块级作用域,不可以重复声明。在全局环境下声明不会成为顶层对象的属性。

其中const声明常量,需要在声明的同时赋值,并且变量的值之后不能改变。

HTML元素的动态获取和静态获取

  • 动态获取: 获取的变量是一组元素,当其中一个发生改变,第二次操作这组元素时,就会从新获取一次,不在计算改变的那一个 。讲白了就是根据特点的特征来捕获,只要你是美女不管你是不是化了妆都会被选上。

    getElementsByClassName/TagName/Name

  • 静态获取:获取之后,就制定某一个对象或者节点,和节点的任何变化都没有关系 。讲白了就是就算你改了名整了容,化成灰我都认得你。

    getElementsById/querySelector/querySelectorAll

this的指向问题

默认绑定

  • 在全局环境或是函数自执行情况下,this指向全局变量window

  • 被作为某个对象的方法调用时候,this指向那个对象

  • 被嵌套的函数独立调用时this指向window

var a = 0;
var obj = {
a : 2,
foo:function(){
function test(){
console.log(this.a);
}
test();
}
}
obj.foo(); //window
  • 闭包中里面函数独立调用,而不是方法调用,this默认绑定到window

隐式绑定

  • 一般被直接对象所包含的函数调用时,也称之为方法调用,this隐式绑定到该直接对象
function fun(){
console.log(this.a);
};
var obj1 = {
a : 1,
foo:fun,
obj2:{
a : 2,
foo :fun
}
}
obj1.foo();//1
obj1.obj2.foo();//2

箭头函数

  • 箭头函数没有自己的 this,当在内部使用了 this时,它会指向最近一层作用域内的 this

严格模式

  • 严格模式下this指向顶层对象window

还有一些奇葩操作。。。

object.getName和(object.getName)定义是相同的,所以返回'My Object'没有问题

(object.getName = object.getName)这里括号内进行了赋值操作,而这个值是函数本身。再赋值完毕后再调用了自身,所以当作函数自执行返回的是全局变量中的name属性。

var name = 'The window';
var object = {
name : 'My Object',
getName : function(){
return this.name;
}
}; object.getName(); //'My Object'
(object.getName)(); //'My Object'
(object.getName = object.getName)(); //'The window'

DOM节点css样式对象的读取

IE:node.currentStyle

非IE: getComputedStyle(node)

兼容: function getCSS(node){ return node.currentStyle || getComputedStyle(node);}

前端知识点回顾——Javascript篇(一)的更多相关文章

  1. 前端知识点回顾——Javascript篇(二)

    JavaScript的解析顺序 第一阶段:编译期 寻找关键字声明的变量.函数声明的变量,同时会对变量进行作用域的绑定 var声明的变量,在编译期会赋一个默认值undefined,变量提升的特性. ES ...

  2. 前端知识点回顾——Javascript篇(六)

    fetch 在原生ajax+es6promise的基础上封装的一个语法糖,返回promise对象. fetch(url, initObj) .then(res=>res.json()) .the ...

  3. 前端知识点回顾——Javascript篇(五)

    DOM 常用的DOM获取方法: node.children 返回子元素节点,没有兼容性问题,动态获取 node.parentNode 获取父节点,没有兼容性问题 node.offsetParent 获 ...

  4. 前端知识点回顾——Javascript篇(四)

    Symbol 为什么需要symbol ES5里面对象的属性名都是字符串,如果你需要使用一个别人提供的对象,你对这个对象有哪些属性也不是很清楚,但又想为这个对象新增一些属性,那么你新增的属性名就很可能和 ...

  5. 前端知识点回顾——Javascript篇(三)

    数组的冒泡.选择和插入排序法 冒泡排序法(从小到大) function bubble(arr){ for(let i = 0 ;i<arr.length-1;i++){ for(let j = ...

  6. web前端知识点(JavaScript篇)

    call,apply,bind call,apply,bind这三者的区别,及内部实现原理,点这里 promise promise函数的内部实现原理,点这里 闭包 闭包就是能够读取其他函数内部变量的函 ...

  7. 前端知识点回顾——HTML,CSS篇

    前端知识点回顾篇--是我当初刚转行为了面试而将自己学过的前端知识整理成的一份笔记,个人目的性很强,仅供参考. doctype 有什么用 doctype是一种标准通用标记语言的文档类型声明,目的是告诉标 ...

  8. [转] Web前端优化之 Javascript篇

    原文链接: http://lunax.info/archives/3099.html Web 前端优化最佳实践之 JavaScript 篇,这部分有 6 条规则,和 CSS 篇 重复的有几条.前端优化 ...

  9. 前端开发之JavaScript篇

    一.JavaScript介绍  前端三剑客之JavaScript,简称js,可能是这三个里面最难的一个了.很早以前,市面上流通着三种js版本,为了统一,ECMA(欧洲计算机制造协会)定义了规范的版本, ...

随机推荐

  1. PLSQL导入导出数据库

    使用sql脚本和plsql完成数据库的导入导出 1. 准备数据库创建脚本 [SQL] 创建数据库表空间: 格式:create tablespace 表空间名 datafile ‘数据文件位置及名称’ ...

  2. MySQL时间类型及获取、展示处理

    MySQL时间格式 mysql所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期格式 最小值 最大值 零值 ...

  3. vue常用知识点

    vue中图片路径写法 <img :src="avatorSrc" alt=""> <img :src="avatorSrc2&quo ...

  4. C#面向对象(五大基本原则 )

    五大原则 单一职责原则(SRP)开放封闭原则(OCP) 里氏替换原则(LSP) 依赖倒置原则(DIP) 接口隔离原则(ISP)  一.单一职责原则SRP(Single Responsibility P ...

  5. 阿里十年架构师告诉你Spring Boot与Spring Cloud是什么关系

    SpringBoot先于Spring Cloud问世.SpringBoot相当于脚手架,借助他可以快速搭建房子,它本身不具备任何功能属性,值是普通房间,没有其他任何功能. 什么是Spring Boot ...

  6. Servlet和JSP学习总结

    目录 Jsp会被编译成servlet,在页面被第一次访问的时候 Jsp中可以在html页面中嵌入java代码或者引入jsp标签 可以在html中引入自定义标签 Web工程的目录结构 Jsp的注释 Js ...

  7. Educational Codeforces Round 37 G. List Of Integers (二分,容斥定律,数论)

    G. List Of Integers time limit per test 5 seconds memory limit per test 256 megabytes input standard ...

  8. OpenJudge POJ C19C 贪心

    https://cn.vjudge.net/contest/309482#problem/C #include<bits/stdc++.h> using namespace std; ty ...

  9. [转载]Java并发编程:volatile关键字解析

    Java并发编程:volatile关键字解析 volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果.在 ...

  10. 老瞎眼 pk 小鲜肉 (线段树)

    链接:https://ac.nowcoder.com/acm/contest/1114/E来源:牛客网 题目描述 老瞎眼有一个长度为 n 的数组 a,为了为难小鲜肉,他准备了 Q 次询问,每次给出 一 ...