最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

multiplication - Javascript - multiplying a value with itself - Stack Overflow

programmeradmin2浏览0评论

I want to write a script that multiplies any number in a text field with itself by the push of a button and gives the result as an alert. I'm pletely new to Javascript (and have to write my first exam later today). The syntax is killing me, sometimes so similar to Java, but than again not.

Here's what I came up with so far:

<!DOCTYPE html>
<html>
<head>
<script>
function myMultiply()
{
var x= $('#num1').val();
var y= x*x;
alert(x+" times "+x+" equals "+y);
return false;
}
</script>
</head>

<body>

<input type="text" id="num1">

<button onclick="myMultiply()">Try it</button>

<p>By clicking the button above, the value in the text field will be multiplied with itself.</p>

</body>
</html>

I want to write a script that multiplies any number in a text field with itself by the push of a button and gives the result as an alert. I'm pletely new to Javascript (and have to write my first exam later today). The syntax is killing me, sometimes so similar to Java, but than again not.

Here's what I came up with so far:

<!DOCTYPE html>
<html>
<head>
<script>
function myMultiply()
{
var x= $('#num1').val();
var y= x*x;
alert(x+" times "+x+" equals "+y);
return false;
}
</script>
</head>

<body>

<input type="text" id="num1">

<button onclick="myMultiply()">Try it</button>

<p>By clicking the button above, the value in the text field will be multiplied with itself.</p>

</body>
</html>
Share Improve this question edited Apr 30, 2018 at 0:48 Pharap 4,0925 gold badges42 silver badges51 bronze badges asked Feb 21, 2014 at 6:55 SuperSpitterSuperSpitter 1772 silver badges8 bronze badges 1
  • There are brilliant answers about Java vs. Javascript here: stackoverflow./questions/245062/… – Shomz Commented Feb 21, 2014 at 7:12
Add a ment  | 

5 Answers 5

Reset to default 4

You'll want to make sure you parse the input value as it will be a string when you query for it. To operate on it using multiplication, you need a number. You'll usually want to pass 10 as the second radix parameter as there are different implementations of parseInt

function myMultiply() {
    var x = parseInt($('#num1').val(), 10);
    var y = x*x;
    alert(x + " times " + x + " equals " + y);
    return false;
}

You cant multiply string it will be concatenated, parse value to int using parseInt first

parseInt

function myMultiply()
{
    var x= parseInt($('#num1').val(), 10);
    var y= x*x;
    alert(x+" times "+x+" equals "+y);
    return false;
}

try replacing var y=x*x; with var y=Number(x)*Number(x);

Along with other answers indicating you should parseInt it should be noted that you aren't currently including jQuery (which gives you access to the $(".element") notation).

jQuery is a very mon javascript library that saves a lot of time for very mon Javascript tasks (selectors, events etc). You'll see the $() notation in many tutorials and to use it you need to include jQuery.

This will work:

<!DOCTYPE html>
<html>
<head>
        <script src="//ajax.googleapis./ajax/libs/jquery/1.10.2/jquery.min.js"></script>
        <script>
        function myMultiply()
        {
                var x= parseInt( $('#num1').val(), 10 );
                var y= x*x;
                alert(x+" times "+x+" equals "+y);
                return false;
        }
        </script>
</head>

<body>

        <input type="text" id="num1" />
        <button onclick="myMultiply()">Try it</button>
        <p>By clicking the button above, the value in the text field will be multiplied with itself.</p>

</body>
</html>

Your code is fine. You are simply missing the jquery include.

Add <script src="http://ajax.googleapis./ajax/libs/jquery/1.9.1/jquery.min.js"></script> right above your other script and everything works unchanged.

Javascript will parse strings and convert them to numbers automatically when it sees that you are trying to multiply. "4" * "2" is 8, not "44" or "42" or any other magical bination. You have a syntax error by referring to $ without actually including jQuery as a required script, so the function ends up being undefined.

<!DOCTYPE html>
<html>
<head>
  <script src="http://ajax.googleapis./ajax/libs/jquery/1.9.1/jquery.min.js"></script>
  <script type="text/javascript">
    function myMultiply()
    {
      var x= $('#num1').val();
      var y= x*x;
      alert(x+" times "+x+" equals "+y);
      return false;
    }
  </script>
</head>

<body>

<input type="text" id="num1">

<button onclick="myMultiply()">Try it</button>

<p>By clicking the button above, the value in the text field will be multiplied with itself.</p>

</body>
</html>
发布评论

评论列表(0)

  1. 暂无评论