JS定义的位置

发布网友 发布时间:2022-04-23 04:54

我来回答

3个回答

热心网友 时间:2022-05-16 09:54

<script>...</script>
这个标签放的位置你首先要了解页面加载顺序.
HTML页面是从上至下顺序加载的.最后全加载完执行onload事件
你现在这种情况放在前面不好使,我估计你是在其中直接执行了调用页面元素的方法.
例子1:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<SCRIPT LANGUAGE="JavaScript">
<!--
alert(document.all("a").value);
//-->
</SCRIPT>
</HEAD>

<BODY>
<INPUT TYPE="text" NAME="a" value="xxxx">
</BODY>
</HTML>
例子2:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>

<BODY>
<INPUT TYPE="text" NAME="a" value="xxxx">
</BODY>
</HTML>
<SCRIPT LANGUAGE="JavaScript">
<!--
alert(document.all("a").value);
//-->
</SCRIPT>
例子3:
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<SCRIPT LANGUAGE="JavaScript">
<!--
function aa(){
alert(document.all("a").value);
}
//-->
</SCRIPT>
</HEAD>

<BODY onload="aa()">
<INPUT TYPE="text" NAME="a" value="xxxx">
</BODY>
</HTML>
你运行下这3个例子分别是3类情况

热心网友 时间:2022-05-16 11:12

一、js全局变量和局部变量

1、全局变量和它的作用域
  全局变量是指在程序开头的说明部分定义和说明的量。它的作用域分为两种情况:
    1)在全局变量和局部变量不同名时,其作用域是整个程序。
    2)在全局变量和局部变量同名时,全局变量的作用域不包含同名局部变量的作用域。
2、局部变量和它的作用域
  凡是在子程序内部使用的变量,必须在子程序中加入说明。这种在子程序内部说明的变量称为局部变量。局部变量的作用域是其所在的子程序。形式参数也只能在子程序中有效。因此也属于局部变量。局部变量的作用域分为两种情况:
    1)当外层过程序的局部变量名和嵌套过程中的局部变量不同名时,外层过程的局部变量作用域包含嵌套过琛。
    2)当外层过程的局部变量名和嵌套过程内的局部变量名同名时,外层局部变量名的作用域不包含此过程。


二、js定义变量需要注意以下内容:

1、Javascript的变量的scope是根据方法块来划分的(也就是说以function的一对大括号{ }来划分);切记,是function块,而for、while、if块并不是作用域的划分标准

2、Javascript在执行前会对整个脚本文件的声明部分做完整分析(包括局部变量),从而确定实变量的作用域

3、当全局变量跟局部变量重名时,局部变量的scope会覆盖掉全局变量的scope,当离开局部变量的scope后,又重回到全局变量的scope


三、js定义变量时,var和this的区别

1、var的规则是: 使用var声明变量就是内部变量, 否则就是先调用全局变量, 不管多少层函数
2、this的规则是: method函数里的this永远指向自身, 普通函数的this永远指向DOMWindow


附件为var和this区别的示例代码!

热心网友 时间:2022-05-16 12:46

  js代码可以放在jsp的<head></head>中,也可以放在<body></body>中。引用js代码也是有分2种方式的:
  1、单独写个文件夹,然后写个js文件放置放在文件夹里,然后在jsp页面通过
  <script src="js文件的相对地址">来导入。
  2、通过<script type="text/javascript"></script>标签,将js代码放入标签里。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com