js中的对象的引用

JavaScript026

js中的对象的引用,第1张

是不一样的,可以这么说,同一个构造函数,无论在哪儿实例化对象,在内存中的地址是不一样的,没实例化一次,就会对应新的内存地址。你可以在构造函数中,声明一个随机数变量:如var suiji = Math.random() 然后实例化对象,输出这个变量,那肯定不是一样的,说明不是一块内存地址。

这个问题是可以办到的。

最关键的地方是获得调用者的名称,需要用到 arguments 对象读取 js 的调用栈。

function search(){

// 以下两句是等效的

alert(search.caller.name)

alert(arguments.callee.caller.name)

}

function baidu(){

search()

}

function google(){

search()

}

google()

baidu()

执行以上代码会分别得到 google 和 baidu。下面是对调用的对象分解解说:

name 和 caller 属性:

在 js(正确的名称应该是:ECMAScript) 里一切都是对象,变量就不用说了,连函数也是作为对象存在的。每个函数都有 name 和 caller 属性,name 属性返回函数的名称,而 caller 属性返回的是调用它的函数对象(是对象不是名称)。

arguments 对象及它的 callee 属性:

而函数在调用开始会生成一个 arguments 对象,这个对象不光能读取到转递给函数的参数,还能通过 callee 属性返回生成它的函数对象,在上面的例子中 arguments.callee == search 函数对象,使用 arguments.callee 的好处是当 search 函数改名也不会影响程序的正确性。

根据以上两条,不难得到 arguments.callee.caller.name 就是当前函数的调用者名称了

你把index1.js 中的onReady 去掉,把index1.js改成 function index1() { 请确定他们在一个文件夹下,然后就可以直接调用了 直接把两段代码合并 。 希望能给你帮助。