<script type="text/javascript">
function Sing()
{
alert(author + ":" + poem); //此函数内的变量是函数外定义的全局变量
};
var author = "李白";
var poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归";
Sing();
</script>//能正常运行<script type="text/javascript">
function Sing()
{
with(arguments.callee)
alert(author + ":" + poem); //此函数内的变量是在函数定义之外赋值的
};
Sing.author = "李白";
Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归";
Sing();
</script>//能正常运行,我能理解<script type="text/javascript">
function Sing()
{
alert(author + ":" + poem); //此函数内的变量在函数外赋值了,为什么不能正常运行?
};
Sing.author = "李白"; //这是对函数一个属性的赋值
Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值
Sing();
</script>//为什么不能正常运行?难道函数定义内、外的 author、poem
不是同一概念?我理解不了,请大家解释
function Sing()
{
alert(author + ":" + poem); //此函数内的变量是函数外定义的全局变量
};
var author = "李白";
var poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归";
Sing();
</script>//能正常运行<script type="text/javascript">
function Sing()
{
with(arguments.callee)
alert(author + ":" + poem); //此函数内的变量是在函数定义之外赋值的
};
Sing.author = "李白";
Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归";
Sing();
</script>//能正常运行,我能理解<script type="text/javascript">
function Sing()
{
alert(author + ":" + poem); //此函数内的变量在函数外赋值了,为什么不能正常运行?
};
Sing.author = "李白"; //这是对函数一个属性的赋值
Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值
Sing();
</script>//为什么不能正常运行?难道函数定义内、外的 author、poem
不是同一概念?我理解不了,请大家解释
<script type="text/javascript">
function Sing()
{
alert(this.author + ":" + this.poem); //此函数内的变量在函数外赋值了,为什么不能正常运行?
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值
Sing.call(Sing);
</script>
function Sing()
{
alert(this==window);//这里的this对象是window.,而author只Sing这个对象的一个属性
alert(Sing.author + ":" + this.poem); //此函数内的变量在函数外赋值了,为什么不能正常运行?
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值 Sing();
默认的指针是window.
相当于window才是一个JAVA Class.
我一直把JS的函数看成类级了(因为函数对象).
但是对函数对象来说.
这个this要更复杂点.
呵呵.
function Sing()
{
alert(this==window);//这里的this对象是window
var author="xiao li";//这里定义的变量author与函数外定义的属性author有什么区别?
alert(Sing.author + ":" + this.poem);
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值 Sing(); </script>
alert(author + ":" + poem); //此函数内的变量是在函数定义之外赋值的。 == alert(Sing.author+":"+Sing.poem);
function Sing()
{
alert(this==window);//这里的this对象是window
var author="xiao li";//这里定义的变量author与函数外定义的属性author有什么区别? alert(Sing.author + ":" + this.poem);
};
Sing.author = "李白"; //函数外定义的属性author,与函数内定义的author有什么区别? Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值 Sing(); </script>
//我的问题是,函数内外定义的同名变量,有什么区别?
arguments.callee 理解为Sing对象
with(arguments.callee)
alert(author + ":" + poem); //此函数内的变量是在函数定义之外赋值的
}; 实际可以理解为
alert(Sing.author+":"+Sing.poem) 当然可以顺利执行。但楼主提出的<script type="text/javascript">
function Sing()
{
alert(author + ":" + poem); //此函数内的变量在函数外赋值了,为什么不能正常运行?
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值 Sing();
</script>中的 alert(author+":"+poem) 肯定会把 author ,poem未定义的错误
因为js引擎首先会去找你是否定义了author与poem变量,如果没有定义,则他会去window对象下查找,如果还是没有,则会抛出异常。
楼主下面定义的Sing.author与Sing.poem只是Sing对象的两个属性,与alert中的没有任何关系!
不知楼主是否明白了。只要能理解callee,就清楚了。
{
alert(this.author + ":" + this.poem); //这里的this 指的是 window
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值 Sing();
var song=new Sing();
song()//这里的this 指的才是 song 本身。不要再弄混了。还有,prototype属性,指的是由它生成的对象的属性,而不是它本身的属性。也不要弄混了。
<script type="text/javascript">
function Sing()
{
alert(this.author + ":" + this.poem); //此函数内的变量在函数外赋值了,为什么不能正常运行? 因为这个时候的 this == window
};
Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值
Sing.call(Sing);
</script>
<script type="text/javascript">
function Sing()
{
var author = "李白";
// alert(this.author + ":" + this.poem);
};
//Sing.author = "李白"; //这是对函数一个属性的赋值 Sing.poem = "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"; //这是对函数一个属性的赋值
alert(Sing.author); // undefined
alert(Sing.poem); // "汉家秦地月,流影照明妃。一上玉关道,天涯去不归"
</script>