[笔记]Javascript中的11个难以理解的问题
来源:互联网 发布:机械制作软件 编辑:程序博客网 时间:2024/04/30 04:39
看了这个人的javascript系列, 很受教育, 做了一些笔记.
http://www.cnblogs.com/fool/tag/%E7%90%86%E8%A7%A3Javascript/
- 原始值与引用值
原始值存放在栈里, 引用值存放在堆里. 如程序:function Person(id,name,age){this.id = id;this.name = name;this.age = age;}var num = 10;var bol = true;var str = "abc";var obj = new Object();var arr = ['a','b','c'];var person = new Person(100,"笨蛋的座右铭",25);
- undefined和null
undefined: 变量未定义; 是Undefined类型的专属值;
null:引用未分配; 是Null类型的专属值.
typeof(undefined) == undefined;
typeof(null) == object;
undefined==null;
undefined!==null;
null instanceof Object == false;
undefined instanceof Object == false;
虽然有Undefined和Null类型, 但是通过下面的例子说明这两个类型是不可见的, 也就是说我们只能使用他们的值:
alert(undefined instanceof Undefined);
alert(null instanceof Null); - 伪数组
特点: 1) 具有length属性; 2) 像数组一样按索引顺序存取数据; 3) 不具备数组特有的操作数据的方法如push, pop, slice...
伪数组都可以通过Array.prototype.slice转换为真正的数组:
var faceArray = {0: 'a', 1: 'b', length: 2}//标准的伪数组;
var realArray = Array.prototype.slice.call(fakeArray);
js中的伪数组:arguments, node.childNodes, document.getElementsByTagName()...
IE中的问题: IE中node.childNodes是不能用slice转化的.
Jquery中的伪数组: Jquery本身就是一个伪数组:
alert($('.class1').length); alert($('.class1').[0].tagName); - 关于简单类型的字面量
var a = 1; b = true, c = "ccc";
字面量看起来有类型
alert(typeof a);//number
alert(typeof b);//boolean
alert(typeof c);//string
但是通过instanceof却测不出来
alert(a instanceof Number)//false
alert(a instanceof Object)//false
alert(b instanceof Boolean)//false
alert(b instanceof Object)//false
alert(c instanceof String)//false
alert(c instanceof Object)//false - 函数的prototype属性和对象实例的内部prototype属性
每个function(构造函数)都有一个prototype属性, 每个对象实例都有一个不可见的(mozilla把它公开了, 可以通过__proto__来取得)内部的prototype属性, 它指向构造函数的prototype属性. prototype还可以有它自己的prototype属性, 这构成了prototype链, Object是最顶的对象, 所以所有的prototype链最终会指向Object.prototype. 当访问对象实例的属性/方法的时候, 从对象实例自己开始搜索, 若果搜索不到, 沿着prototype链向上搜索, 直到Object.prototype.prototype == null 为止. - 构造函数的一个小秘密
var s = new function(){return "sss"};
alert(s);//[object Object]
s = new function(){return new String("sss")};
alert(s);//sss
关于这段代码的解释:
只要 new 表达式之后的 constructor 返回(return)一个引用对象(数组,对象,函数等),都将覆盖new创建的匿名对象,如果返回(return)一个原始类型(无 return 时其实为 return 原始类型 undefined),那么就返回 new 创建的匿名对象. - 对象的创建的过程
function Person(name){
this.name = name;
}
Person.prototype = {
getName: function(){return this.name}
};
var p = new Person('zhangsan');
解密p的创建过程:- 创建一个build-in object对象obj并初始化;
- 将p的内部[[Prototype]]指向Person.prototype;
- 将p作为this,使用arguments参数调用Person的内部[[Call]]方法, 即执行Person函数体, 并返回返回值, 如果没有return, 则返回undefined;
- 如果前一步返回的是Object类型, 则返回这个值给p, 否则返回obj.
- 对象的自有属性和继承属性
function Person(name){
this.name = name;
}
Person.prototype = {
type: 'human',
getName: function(){return this.name}
};
var p = new Person('zhangsan');
alert(p.hasOwnProperty('type'));//false
p.type = 'ren';
alert(p.hasOwnProperty('type'));//true
运行结果很明确,对象的属性无法修改其原型中的同名属性,而只会自身创建一个同名属性并为其赋值。 - 函数对象的创建过程
创建一个build-in object对象fn;
将fn的内部[[Prototype]]设为Function.prototype;
设置内部的[[Call]]属性,它是内部实现的一个方法,处理函数调用的逻辑。(简单的理解为指向函数体);
设置fn.length为funArgs.length,如果函数没有参数,则将fn.length设置为0;
fn.prototype的constructor指向fn自己;
返回fn. - instanceof的原理
查看a是不是B的实例, 就是看B的prototype(构造函数的prototype属性)指向的对象在不在a的原形链上. - 关于Function和Object的猜测
alert(Function instanceof Function);//true
alert(Function instanceof Object);//true
alert(Object instanceof Function);//true
alert(Object instanceof Object);//true
想了好久, 没有想透......
- [笔记]Javascript中的11个难以理解的问题
- EL表达式中的${}出现难以查到的JasperException问题
- 难以理解的程序课
- “难以理解”的玉文化
- 一道难以解决的问题
- IOS开发学习笔记(二十二)——ObjectC语言难以理解的概念汇总
- 几个难以理解的设计模式
- object-c难以理解的一些概念
- Object-C难以理解的一些概念
- Object-C难以理解的一些概念
- Object-C难以理解的一些概念
- 为什么你的代码如此难以理解
- 一个难忘而又难以理解的代码
- 那些难以理解的数据结构基本概念
- javascript 中的call函数的理解问题;apply
- 看到一篇博客写的kmp算法,由于才疏学浅,难以理解,干脆自己实现个kmp算法
- Android ARM指令比较难以理解问题总结
- 难以察觉的环形include问题
- ASP.NET MVC HtmlHelper用法大全
- 教育培训服务业的电子商务在哪里?未来这个领域商业机会在哪?现在发展过程的困境是什么?
- 为什么要禁止在正式程序中使用sleep语句?
- 工作队列 的变化
- C语言的3des、java的3des、C#的3des。三种加密遇到的问题
- [笔记]Javascript中的11个难以理解的问题
- SQL 2005: SSIS – PUSHING DATA TO MYSQL USING SCRIPT COMPONENT DESTINATION
- ubuntu普通用户进入根目录的方法
- Java版中文转汉语拼音工具
- 英语
- cp 复制文件与文件夹
- JAVA功能代码《5》----将Java中的util.Date转换成sql.Date
- Configuring a Gateway of Last Resort Using IP Commands
- Xfire 图片(image) webservice byte 加密 传输 ---- 上传