如何从两个Jtextfield计算数字?

问题描述

我正在设计一种食品订购系统,我需要获取客户支付的现金输入,然后减去他们需要支付的总价来计算零钱。我的JTextField无法显示更改的正确答案,仅显示0.0。我不确定我的代码有什么问题。希望大家能帮助我。感谢您的帮助,谢谢!

public Cash() {
    init();
    btnPay.addActionListener(this);
    setVisible(true);
}

public String returnChange1() {
    double change = 0.00 ;
    double custPay;
    String total = lbldisplayTotal.getText();
    double a=Double.parseDouble(total);

    if (!(txtCustPay.getText().isEmpty())){
        custPay = Double.parseDouble(txtCustPay.getText());
        change = custPay - a;
    }
    return String.valueOf(change);
}

public void actionPerformed(ActionEvent e) {
    if (e.getSource().equals(btnPay)) {
        returnChange1();
    }
}

public void init() {
    txtChange = new JTextField(returnChange1());
    txtChange.setSize(150,30);
    txtChange.setLocation(150,250);
    add(txtChange);
}

解决方法

您没有将功能分配给文本字段。在按钮操作中,不要简单地调用该函数,在这种情况下,您应该将函数分配给文本字段:txtChange.setText(returnChange1()),也请尝试一下并抓住将文本转换为double的地方:

try{
    double a = Double.parseDouble(total);
}catch(NumberFormatException e){
    e.printStackTrace;
}

当用户错误输入不是数字的字符时,上述代码很有用。

public Cash() {
      
    init();
    btnPay.addActionListener(this);
    setVisible(true);

}

public String returnChange1() {

    double change = 0.00;
    double custPay;
    String total = lblDisplayTotal.getText();
    double a = Double.parseDouble(total);

    if (!(txtCustPay.getText().isEmpty())) {
        custPay = Double.parseDouble(txtCustPay.getText());
        change = custPay - a;
    }

    return String.valueOf(change);

}

public void actionPerformed(ActionEvent e) {

    if (e.getSource().equals(btnPay)) {
        txtChange.setText(returnChange1());
    }
}

public void init() {
    txtChange = new JTextField(returnChange1());
    txtChange.setSize(150,30);
    txtChange.setLocation(150,250);
    add(txtChange);
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...