全局对象window
- 在标准里面全局对象叫glabol(浏览器windos)
-
属性举例global.parseInt
1
-
每次页面生成时,会声明一个glabol
2
-
window的属性
3
- window.可以不加
全局函数
-
每个浏览器实现不同的函数
4
5
6
7
8
9
-
临时转换,tamp用了就没了
10
- n.xxx的临时变量产生被赋值2,用完后抹杀了。
各种API
data:image/s3,"s3://crabby-images/844b4/844b4cb17d0b697fedd7c04559ffbba4c8d7139f" alt=""
data:image/s3,"s3://crabby-images/b2c00/b2c00acbdf3cbd6b46f00b50b75b93b91332d6ee" alt=""
data:image/s3,"s3://crabby-images/1710c/1710cad4f85f0075f208ee17fae83d86e0944c4c" alt=""
data:image/s3,"s3://crabby-images/f0c6c/f0c6cf76cf7e9171b7ef5d50d1972516c45ea380" alt=""
-
包前不包后
15
16
17
18
19
- 所有声明对象不相等
用的属性藏在哪里
问题:公用属性
data:image/s3,"s3://crabby-images/b5e11/b5e1164ccea597cdfb364234dc3a41f6bae1cdf4" alt=""
data:image/s3,"s3://crabby-images/d724f/d724f793ff82f2080da8ab350e971d70d3b73ca5" alt=""
data:image/s3,"s3://crabby-images/694b3/694b3a53076a2dddc09c0b2c4d215d66caf9b844" alt=""
toString是哪来的----原型链
data:image/s3,"s3://crabby-images/30af5/30af5c005cd87d0ae1dd953f14f1d03e1432bb87" alt=""
data:image/s3,"s3://crabby-images/07b15/07b15039d55fc44e9f9c5bcaa7ee97697eb834d0" alt=""
-
原型=共有属性
25z
26
27
-
当声明对象时,js引擎除了在栈里弄出哈希外,还__p指向共有属性
28
- String.prototype是String的公用属性
的引用(防止跑的) - s.proto是String的公用属性的引用(用的)
形式上区别
data:image/s3,"s3://crabby-images/8fddf/8fddf619615f0315031cc773db8ae75e49abe4c9" alt=""
data:image/s3,"s3://crabby-images/46e79/46e79c3ba6fcce4971a34118990ac0210d23c4dc" alt=""
1.对象属性
2.函数属性
data:image/s3,"s3://crabby-images/baeab/baeab784fe15fe04b920a27985b3d418a1f899ce" alt=""
data:image/s3,"s3://crabby-images/794a8/794a857e17a3ac8be52ff0701bd7220b2ad09643" alt=""
- 画图的时候认为 Object.proto === Object.prototype ,
实际上应该是 Object.proto === Function.prototype,因为 Function 是 Object 的构造函数。 - 画图时认为 Object.prototype.proto 指向自己,
实际上应该是指向 null
注意大小写,number 和 Number 是不同的
重要公式
- var 对象 = new 函数()
对象.proto === 对象的构造函数.prototype
// 推论
- var number = new Number()
number.proto = Number.prototype
- var object = new Object()
object.proto = Object.prototype
- var function = new Function()
function.proto = Function.prototype
// 另外,所有函数都是由 Function 构造出来的,所以
- Number.proto = Function.prototype // 因为 Number 是函数,是 Function 的实例
- Object.proto = Function.prototype // 因为 Object 是函数,是 Function 的实例
- Function.proto == Function.prototye // 因为 Function 是函数,是 Function 的实例!
网友评论