首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使“计算器”按钮的值在单击“计算器”按钮时显示在显示器上?

如何使“计算器”按钮的值在单击“计算器”按钮时显示在显示器上?
EN

Stack Overflow用户
提问于 2018-10-04 18:07:03
回答 1查看 926关注 0票数 2

这是我在这里的第一篇文章,所以如果我搞砸了我的邮件格式,我会提前道歉。

我正在做CareerFoundry网络开发课程,我们被要求使用javascript和jQuery编写一个计算器。我对编码完全陌生,这对我来说是非常令人困惑的。到目前为止,我已经成功地使用HTML、CSS和Javascript创建和样式了我的计算器,现在我需要使它具有功能。我在这一步,我想点击任何计算器按钮,并使其价值出现在显示div。我不知道怎么做.我试着使用附加方法,但是它不能用我编码的方式.另外,你能给我什么提示,如何在解决这一步骤后继续吗?谢谢!

HTML

代码语言:javascript
运行
复制
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Calculator</title>
    <link rel="stylesheet" type="text/css" href="css/styles.css">
    <link rel="stylesheet" type="text/css" href="css/normalize.css">
  </head>
  <body>
    <div id="calculator">
      <div id="display"></div>
      <div class="row" id="interface"></div>
      <div class="button" id="CE"><p>CE</p></div>
    </div><!-- end calculator -->

    <script src="https://code.jquery.com/jquery-3.3.1.min.js" 
integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" 
crossorigin="anonymous"></script>
    <script src="js/interfaceItems.js"></script>
    <script src="js/scripts.js"></script>
  </body>
</html>

CSS

代码语言:javascript
运行
复制
body {
  font-family: "Century Gothic", Arial, Lucida, Tahoma, Verdana, sans-serif;
  font-size: 2em;
}

#calculator {
  position: fixed;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 320px;
  border: 1px solid grey;
  border-radius: 10px;
  background-color: #404040;
  box-shadow: 5px 10px 20px;
}

#display {
  display: flex;
  justify-content: center;
  text-align: right;
  height: 73px;
  width: 100%;
  margin: 10px 10px 5px 10px;
  border: 1px solid lightgrey;
  border-radius: 5px;
  padding: 5px;
  background-color: #fff;
}

.row {
  display: grid;
  grid-template-columns: repeat(4, auto);
  grid-gap: 2.5px;
  justify-content: center;
  margin: 0 10px 2.5px 10px;
}

.button {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 73px;
  height: 73px;
  border-radius: 5px;
  background-color: skyblue;
}

#CE {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  height: 73px;
  border-radius: 5px;
  margin: 0 10px 10px 10px;
  background-color: skyblue;

}

.button:hover,
#CE:hover {
  cursor: pointer;
  background-color: #fff;
}

.button:active,
#CE:active {
  transform: scale(0.98,0.98);
  box-shadow: 1px 1px 5px;
}

JS

代码语言:javascript
运行
复制
$(document).ready(function(){
  for(var i = 0; i < interfaceItems.length; ++i) {
    $('#interface').append('\
      <div class="button">\
        <p>' + interfaceItems[i].text + '</p>\
      </div>\
    ');
    $('#interface .button', this).on('click', function() {
      $('#display').append('<p>' + interfaceItems[i].value + '</p>');
    });
  };
});

var interfaceItems = [
    {
        text: '7',
        value: 7
    },
    {
        text: '8',
        value: 8
    },
    {
        text: '9',
        value: 9
    },
    {
        text: '÷',
        value: '/'
    },
    {
        text: '4',
        value: 4
    },
    {
        text: '5',
        value: 5
    },
    {
        text: '6',
        value: 6
    },
    {
        text: '×',
        value: '*'
    },
    {
        text: '1',
        value: 1
    },
    {
        text: '2',
        value: 2
    },
    {
        text: '3',
        value: 3
    },
    {
        text: '−',
        value: '-'
    },
    {
        text: '0',
        value: 0
    },
    {
        text: '.',
        value: '.'
    },
    {
        text: '=',
        value: '='
    },
    {
        text: '+',
        value: '+'
    },
];
EN

回答 1

Stack Overflow用户

发布于 2018-10-04 18:21:10

这个问题的出现是因为一个范围问题/变量问题。

您可以在代码中的这一行获得Uncaught TypeError: Cannot read property 'value' of undefined

代码语言:javascript
运行
复制
$('#display').append('<p>' + interfaceItems[i].value + '</p>');

如果在这一行之前添加控制台日志以获得i的值--您会看到i的值是16。为什么?因为在文档就绪函数上有一个for循环。

for(var i = 0; i < interfaceItems.length; ++i) {

在这个循环的末尾,您将i的值设置为16。因为javascript使用了0个索引,所以即使在interfaceItems数组中有16个元素--第16个索引是未定义的(它只从0到15)。

为了解决这个问题,我想你想摆脱在onclick函数中使用i的问题。你可以用这样的方法

this.innerText.trim()获取项目的文本,然后使用该文本使其出现在计算器中。

您将不得不创建一个新的所以问题,以帮助您的计算机应用程序的其他部分。我希望这解决了你的问题,为什么你的onclick功能不起作用。使用控制台和添加console.log语句来调试javascript代码是非常有用的,并将节省将来的行程。祝您顺利完成计算器应用程序!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52652947

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档