<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title> <script language="javascript" type="text/javascript">
window.onload=function()
{}
function cc()
{
var i=document.forms[0].camera;//只有表单元素才能用name,如DIV没有name
for(var j=0;j<i.length;j++)
{
if(i[j].checked==true)break;
}
alert("选的是:"+i[j].value);} </script></head>
<body>
<form>
<div name="row1">first</div>
<div name="row1">second</div>
<div name="row2">third</div>
<input type="radio" name="camera" id="nikon" value="Nikon"> <input type="radio" name="camera" id="Radio1" value="Nikon2">
<input type="radio" name="camera" id="Radio2" value="Nikon3">
<input type="button" onclick="cc()" value="kkkkkk" />
<label for="nikon">
Canon</label>
</form>
</body>
</html>j居然可以出for使用???为什么呢???
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script language="javascript" type="text/javascript">
window.onload=function(){
}
function cc(){
var i=document.forms[0].camera;
//只有表单元素才能用name,如DIV没有name
for(var j=0;j<i.length;j++){
if(i[j].checked==true)break;
}
alert("选的是:"+i[j].value);
}
</script>
</head>
<body>
<form>
<div name="row1">first</div>
<div name="row1">second</div>
<div name="row2">third</div>
<input type="radio" name="camera" id="nikon" value="Nikon" checked>
<input type="radio" name="camera" id="Radio1" value="Nikon2">
<input type="radio" name="camera" id="Radio2" value="Nikon3">
<input type="button" onclick="cc()" value="kkkkkk" />
<label for="nikon">
Canon</label>
</form>
</body>
</html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title> <script language="javascript" type="text/javascript">
window.onload=function()
{}
function cc()
{
var i=document.forms[0].camera;//只有表单元素才能用name,如DIV没有name
for(var j=0;j<i.length;j++)
{
if(i[j].checked==true)break;
}
alert("选的是:"+i[j].value);} </script></head>
<body>
<form>
<div name="row1">first</div>
<div name="row1">second</div>
<div name="row2">third</div>
<input type="radio" name="camera" id="nikon" value="Nikon"> <input type="radio" name="camera" id="Radio1" value="Nikon2">
<input type="radio" name="camera" id="Radio2" value="Nikon3">
<input type="button" onclick="cc()" value="kkkkkk" />
<label for="nikon">
Canon</label>
</form>
</body>
</html>
j居然可以出for使用???为什么呢???
<script type="text/javascript">
var i;
for(i = 0; i < 3; i++){
}
alert(i)
</script>和
<script type="text/javascript"> for(var i = 0; i < 3; i++){
}
alert(i)
</script>等价的
C#就不能吧,是不是只有Javascript中能哦?
怎么能把JS跟C#相比较呢?ECMAScript的作用域都是公共作用域。函数是个对象,只要是对象内声明定义的都可以在对象内访问得到
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>test1.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script type="text/javascript/>
var glob = 4;//函数外声明全局变量
function fun() {
var height = 20;//函数内用var声明的是局部变量
weight = 50;//函数内不用var声明的是全局变量
}
fun();
alert(weight);
</script>
</head>
<body>
</body>
</html> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>test1.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> <script type="text/javascript/>
var glob = 4;//函数外声明全局变量
function fun() {
var height = 20;//函数内用var声明的是局部变量
weight = 50;//函数内不用var声明的是全局变量
}
fun();
alert(weight);
</script>
</head>
<body>
</body>
</html>
js中没有块状作用域,即用大括号{}包含的。java中则有。在main方法中写入下代码Java代码
public static void main(String... args) {
for(int i=0;i<5;i++) {
//todo
}
{
int j=10;
}
int z = 20;
System.out.println(i);// i不可见,语法分析时报错,即编译不通过
System.out.println(j);// j不可见,语法分析时报错,即编译不通过
System.out.println(z);// z可见,输出20
} public static void main(String... args) {
for(int i=0;i<5;i++) {
//todo
}
{
int j=10;
}
int z = 20;
System.out.println(i);// i不可见,语法分析时报错,即编译不通过
System.out.println(j);// j不可见,语法分析时报错,即编译不通过
System.out.println(z);// z可见,输出20
}
但如果在js中Js代码
for(var i=0;i<5;i++) {
//todo
}
var obj = {name:"Lily"};
for(var attr in obj) {
}
{
var j=10;
}
alert(i);//输出4,没有块状作用域
alert(attr); //输出name,没有块状作用域
alert(j);//输出10,没有块状作用域 for(var i=0;i<5;i++) {
//todo
}var obj = {name:"Lily"};
for(var attr in obj) {}{
var j=10;
}
alert(i);//输出4,没有块状作用域
alert(attr); //输出name,没有块状作用域
alert(j);//输出10,没有块状作用域
这也说明一个问题,避免在全局范围内使用for循环同时声明变量,否则会造成全局命名范围的污染。 当然,js1.7中提出了let关键字声明变量(见https://developer.mozilla.org/cn/New_in_JavaScript_1.7),只作用于for语句范围。Js代码
for(let i=0;i<5;i++) {
//todo
}
alert(i);//运行时报错,提示i未定义 for(let i=0;i<5;i++) {
//todo
}
alert(i);//运行时报错,提示i未定义 js1.7需要这样引用 <script type="application/javascript;version=1.7"/></script>
大哥 你在说啥啊...
不就是个作用域链的问题吗,你自己都说了For中定义的变量在For外用不了,你的例子不是用的了For中定义的变量,因为你在For中没有定义它啊(因为你没用var声明,所以此处的变量为不可知型,默认的采取方式为全局变量采用方式,变量的修改或提取直接按照JS从上到下的顺序来.
也可以,不用var定义的变量也可以使用。而且,不定义返回类型也可以有返回值。
for(var j=0;j<i.length;j++)
{
if(i[j].checked==true)break;
}
alert("选的是:"+i[j].value);
这里的j明明就是For中的局域变量哦?你如何看成的全局变量
懂了吗?