2017-07-07 153 views
0

我想创建一个简单的输入字段,它利用什么inputed计算三角形的面积值,我发现我的一些功能。 我注意到,由于某种原因,我的功能无法访问已在全球范围内创建的变量。像这样:Javascript函数未访问全局范围?

<!DOCTYPE html> 
<html> 
<head> 
    <title></title> 
</head> 
<body> 

input 1: <input type="input" placeholder="Side a" id="sideA"> <br> 
input 2: <input type="input" placeholder="Side b" id="sideB"><br> 
input 3: <input type="input" placeholder="Side c" id="sideC"><br> 
<button onclick=" AreaResults()"> Calculate</button> 

<p id="P_result"> 

    The area of the triangle is: 
</p> 
<script > 



function AreaResults(){ 

var side_a = document.getElementById("sideA").value; 
    var side_b = document.getElementById("sideB").value; 
    var side_c = document.getElementById("sideC").value; 

var Allsides = side_c + side_b + side_a; 
var perimeter = Allsides/2; 
var area = Math.sqrt((perimeter*(perimeter-side_a)*(perimeter-side_b)*(perimeter-side_c))); 


    var resultsInput = document.getElementById("P_result"); 
    resultsInput.append(area); 

} 



</script> 
</body> 
</html> 

一切工作只是罚款:

<!DOCTYPE html> 
<html> 
<head> 
    <title></title> 
</head> 
<body> 

input 1: <input type="input" placeholder="Side a" id="sideA"> <br> 
input 2: <input type="input" placeholder="Side b" id="sideB"><br> 
input 3: <input type="input" placeholder="Side c" id="sideC"><br> 
<button onclick=" AreaResults()"> Calculate</button> 

<p id="P_result"> 

    The area of the triangle is: 
</p> 
<script > 

var side_a = document.getElementById("sideA").value; 
    var side_b = document.getElementById("sideB").value; 
    var side_c = document.getElementById("sideC").value; 

var Allsides = side_c + side_b + side_a; 
var perimeter = Allsides/2; 
var area = Math.sqrt((perimeter*(perimeter-side_a)*(perimeter-side_b)*(perimeter-side_c))); 


function AreaResults(){ 


    var resultsInput = document.getElementById("P_result"); 
    resultsInput.append(area); 

} 



</script> 
</body> 
</html> 

它们移动到函数这样之后。 我不明白,因为我认为函数可以访问在全球范围内

+0

你怎么知道你不能访问它们? – Carcigenicate

+0

代码不起作用,除非我在函数中写入它 – george

回答

6

您所访问的变量就好了所有的变量。

但是,您设置用户输入任何东西(加载页面时)之前,所以他们是空的。