1.ECMAScript DOM BOM
2.简单数据类型
string number boolean undefined
复杂数据类型
Object Array Date RegExp function String Number Boolean Math null
3.typeof 参数
返回值为字符串类型
4.全等是要判断类型和值 等于只判断值
5.in
1.for in 遍历对象的键
2.判断属性是否存在于对象中 属性名 in 对象名 属性名应该是字符串
6.值类型
在内存中直接存储数据本身的就是值类型
引用类型
在内存中存储的是数据的地址,数据单独的存在于内存中,就是引用类型
7.值类型赋值
直接将值复制一份赋值给新的变量
引用类型
讲对象的地址复制一份赋值给新的变量,两个变量同时指向同一个对象,修改其中一个,另一个也受影响
8.值类型做参数
函数内部的形参,和实参的变量,是两个值相同,但是独立存储内存的两个不同的变量,修改一个变量,另一个不受影响
引用类型做参数
函数内部的形参,和实参的变量,存储的是同一个地址,指向的是同一个对象,两个变量共享同一个对象,修改其中一个,另一个也受影响。
9.表达式1 || 表达式2
如果表达式1为真 返回表达式1的值
如果表达式1为假 返回表达式2的值
表达式1 && 表达式2
如果表达式1是假,直接返回表达式1的值
如果表达式1是真,直接返回表达式2的值
10.delete关键字
1.删除对象的属性
2. 删除未使用var关键字声明的变量
返回值 布尔值类型的值,表示是否删除成功。
注意:
1.如果删除不存在的属性,返回true
2.如果删除的是存在于原型中的属性,返回true但未被删除
11.网站优化方案
代码层面:避免使用css表达式,避免使用高级选择器,通配选择器。缓存利用:缓存Ajax,使用CDN,使用外部js和css文件以便缓存,添加Expires头,服务端配置Etag,减少DNS查找等
请求数量:合并样式和脚本,使用css图片精灵,初始首屏之外的图片资源按需加载,静态资源延迟加载。
请求带宽:压缩文件,开启GZIP,
代码层面的优化
用 hash-table 来优化查找
少用全局变量
用 innerHTML 代替 DOM 操作,减少 DOM 操作次数,优化 javascript 性能
用 setTimeout 来避免页面失去响应
缓存DOM节点查找的结果
避免使用CSS Expression
避免全局查询
避免使用with(with会创建自己的作用域,会增加作用域链长度)
多个变量声明合并
避免图片和iFrame等的空Src。空Src会重新加载当前页面,影响速度和效率
尽量避免写在HTML标签中写Style属性
移动端性能优化
尽量使用css3动画,开启硬件加速。
适当使用 touch 事件代替 click 事件。
避免使用 css3 渐变阴影效果。
可以用 transform: translateZ(0) 来开启硬件加速。(见下面的详细解释)
不滥用Float。Float在渲染时计算量比较大,尽量减少使用
不滥用Web字体。Web字体需要下载,解析,重绘当前页面,尽量减少使用。
合理使用requestAnimationFrame动画代替setTimeout
CSS中的属性(CSS3 transitions、CSS3 3D transforms、Opacity、Canvas、WebGL、Video)会触发GPU渲染,请合理使用。过渡使用会引发手机过耗电增加
PC端的在移动端同样适用
注意:任何函数执行完一次,如果没有 return 返回值和声明变量接受返回值,都会立即消失,永远找不到值!
闭包就是能够读取其他函数内部变量的函数
闭包就是将函数内部和函数外部连接起来的一座桥梁。
js所有的匿名函数的this都指向window
JSONP原理
ajax请求受同源策略影响,不允许进行跨域请求,而script标签src属性中的链接却可以访问跨域的js脚本,利用这个特性,服务端不再返回JSON格式的数据,而是返回一段调用某个函数的js代码,在src中进行了调用,这样实现了跨域。