javascript - 如何计算以十为底的数字?
问题描述
所以我正在构建一个只使用 p5.js 的计算器。我已经让数字显示被按下的数字,但我不明白如何让数字显示“层”数字,例如。我点击 2 和 5 我会得到 25。有谁知道如何使这个功能工作。非常感谢您的帮助。谢谢你。
let number = 0;
function setup() {
createCanvas(400, 400);
let one = createButton('1');
one.mousePressed(clickedOne);
let two = createButton('2');
two.mousePressed(clickedTwo);
let three = createButton('3');
three.mousePressed(clickedThree);
let four = createButton('4');
four.mousePressed(clickedFour);
let five = createButton('5');
five.mousePressed(clickedFive);
let six = createButton('6');
six.mousePressed(clickedSix);
let seven = createButton('7');
seven.mousePressed(clickedSeven);
let eight = createButton('8');
eight.mousePressed(clickedEight);
let nine = createButton('9');
nine.mousePressed(clickedNine);
let zero = createButton('0');
zero.mousePressed(clickedZero);
let equals = createButton('=');
let clear = createButton('AC');
let divide = createButton('÷');
let multiply = createButton('x');
let add = createButton('+');
let minus = createButton('-');
one.position(100, 150);
one.size(45, 45);
two.position(144, 150);
two.size(45, 45);
four.position(100, 194);
four.size(45, 45);
six.position(188, 194);
six.size(45, 45);
three.position(188, 150);
three.size(45, 45);
five.position(144, 194);
five.size(45, 45);
seven.position(100, 238);
seven.size(45, 45);
eight.position(144, 238);
eight.size(45, 45);
nine.position(188, 238);
nine.size(45, 45);
zero.position(100, 282);
zero.size(89, 45);
equals.position(188, 282);
equals.size(45, 45);
divide.position(232, 150);
divide.size(45, 45);
multiply.position(232, 194);
multiply.size(45, 45);
add.position(232, 238);
add.size(45, 45);
minus.position(232, 282);
minus.size(45, 45);
clear.position(100, 106);
clear.size(177, 45);
}
function clickedOne(){
number = 1;
}
function clickedTwo(){
number = 2;
}
function clickedThree(){
number = 3;
}
function clickedFour(){
number = 4;
}
function clickedFive(){
number = 5;
}
function clickedSix(){
number = 6;
}
function clickedSeven(){
number = 7;
}
function clickedEight(){
number = 8;
}
function clickedNine(){
number = 9;
}
function clickedZero(){
number = 0;
}
function draw() {
background(220);
noStroke();
fill(20, 255, 255, 30);
rect(100, 53, 177, 54, 5);
strokeWeight(6);
stroke(0);
noFill();
rect(97, 50, 183, 280, 5);
strokeWeight(1);
stroke(0);
text(number, width/2 + 50, 100);
}
解决方案
您必须将当前数字乘以 10 并添加新数字:
例如:
function clickedOne(){
number = number * 10 + 1;
}
function clickedTwo(){
number = number * 10 + 2;
}
推荐阅读
- flutter - 颤动的webview不允许用户代理
- reactjs - 用户登录后反应路由器不重定向
- angular-akita - 如何避免秋田商店重复条目?
- html - Firefox中文本区域的闪烁高度=继承。这可能是什么原因?
- css - 我如何知道我的 WordPress 页面是否是使用 Bootstrap 制作的?
- docker - Docker - 如何通过 jwilder nginx-proxy 公开端口?
- c# - 如何从代码运行 Azure DevOps 管道?
- c++ - 为什么循环没有中断,并且 if 条件也没有按预期工作?
- reactjs - 登录后我的自定义路由无法正常工作
- php - 在 yii 框架中调用未定义的方法 stdClass::save()