java文本输入框_Java开发笔记(一百三十九)JavaFX的输入框

循着Swing的旧例,JavaFX仍然提供了三种文本输入框,分别是单行输入框TextField、密码输入框PasswordField、多行输入框TextArea。这些输入框都由抽象类TextInputControl派生而来,因此拥有共同的编辑方法,常用的主要有下列两个:

setEditable:设置输入框能否编辑。为true表示能够编辑,为false表示不能编辑。

setPromptText:设置输入框的提示语,用来提示用户可以输入什么样的文本。

文本输入框与文本标签的区别在于,输入框内的文字允许编辑,而标签文字不允许编辑。尽管如此,输入框依旧要在界面上显示文字,故而它拥有以下与Label控件同样的方法:

setPrefSize:设置输入框的推荐宽高。

setText:设置输入框的文本。

setFont:设置输入框的字体。

setBackground:设置输入框的背景。

至于Label控件的其它方法如setAlignment、setTextFill、setWrapText、setGraphic,由于涉及到具体细节,因此TextInputControl类并未提供。除此之外,JavaFX的三种输入框各有千秋,接下来将对它们分别予以详细说明。

1、单行输入框TextField

TextField控件对应Swing的JTextField,它只能输入一行的文字,另外提供了下列两个专属方法:

setAlignment:设置输入框的对齐方式。该方法等同于Label控件的同名方法。

setPrefColumnCount:设置输入框的推荐列数。

下面是在界面上添加单行输入框的代码片段:

Button btn1 = new Button("单行输入框"); // 创建一个按钮

btn1.setOnAction(new EventHandler() { // 设置按钮的单击事件

@Override

public void handle(ActionEvent arg0) { // 处理单击事件

HBox hbox = new HBox(); // 创建一个水平箱子

Label label = new Label("请输入手机号码:"); // 创建一个标签

TextField field = new TextField(); // 创建一个单行输入框

field.setPrefSize(200, 50); // 设置单行输入框的推荐宽高

field.setEditable(true); // 设置单行输入框能否编辑

field.setPromptText("请输入手机号码"); // 设置单行输入框的提示语

field.setAlignment(Pos.CENTER_LEFT); // 设置单行输入框的对齐方式

field.setPrefColumnCount(11); // 设置单行输入框的推荐列数

hbox.getChildren().addAll(label, field); // 给水平箱子添加一个单行输入框

borderPane.setCenter(hbox); // 把水平箱子放到边界窗格的中央

}

});

flowPane.getChildren().add(btn1); // 往流式窗格上添加按钮

运行包含以上测试代码的应用程序,单击按钮后的窗口界面如下图所示,可见在TextField中填写的文字以明文显示。

e1288c4a816ce01d073bce799e306e86.png

2、密码输入框PasswordField

PasswordField控件对应Swing的JPasswordField,它实际上继承自TextField,唯一区别是输入的文字以圆点代替,连回显字符的设置方法都未提供。下面是在界面上添加密码输入框的代码片段:

Button btn2 = new Button("密码输入框"); // 创建一个按钮

btn2.setOnAction(new EventHandler() { // 设置按钮的单击事件

@Override

public void handle(ActionEvent arg0) { // 处理单击事件

HBox hbox = new HBox(); // 创建一个水平箱子

Label label = new Label("请输入密码:"); // 创建一个标签

PasswordField field = new PasswordField(); // 创建一个密码输入框

field.setPrefSize(200, 50); // 设置密码输入框的推荐宽高

field.setEditable(true); // 设置密码输入框能否编辑

field.setPromptText("请输入密码"); // 设置密码输入框的提示语

field.setAlignment(Pos.CENTER_LEFT); // 设置密码输入框的对齐方式

field.setPrefColumnCount(11); // 设置密码输入框的推荐列数

hbox.getChildren().addAll(label, field); // 给水平箱子添加一个密码输入框

borderPane.setCenter(hbox); // 把水平箱子放到边界窗格的中央

}

});

flowPane.getChildren().add(btn2); // 往流式窗格上添加按钮

运行包含以上测试代码的应用程序,单击按钮后的窗口界面如下图所示,可见在PasswordField中填写的文字以密文显示。

753e0c5fc6dbb26549b034e1430a77ef.png

3、多行输入框TextArea

TextArea控件对应Swing的JTextArea,它允许输入多行文本,且文字固定朝左上角对齐,所以该控件没有setAlignment方法,反而多出了setWrapText换行方法。TextArea额外多出的几个方法说明如下:

setWrapText:设置输入框文本是否支持自动换行。该方法等同于Label控件的同名方法。

setPrefColumnCount:设置输入框的推荐列数。

setPrefRowCount:设置输入框的推荐行数。

下面是在界面上添加多行输入框的代码片段:

Button btn3 = new Button("多行输入框"); // 创建一个按钮

btn3.setOnAction(new EventHandler() { // 设置按钮的单击事件

@Override

public void handle(ActionEvent arg0) { // 处理单击事件

HBox hbox = new HBox(); // 创建一个水平箱子

hbox.setPrefSize(300, 80); // 设置水平箱子的推荐宽高

Label label = new Label("请输入评价:"); // 创建一个标签

TextArea area = new TextArea(); // 创建一个多行输入框

area.setMaxHeight(85); // 设置多行输入框的最大高度

//area.setMaxWidth(300); // 设置多行输入框的最大宽度

area.setPrefSize(200, 50); // 设置多行输入框的推荐宽高

area.setEditable(true); // 设置多行输入框能否编辑

area.setPromptText("请输入评价"); // 设置多行输入框的提示语

area.setWrapText(true); // 设置多行输入框是否支持自动换行。true表示支持,false表示不支持。

area.setPrefColumnCount(11); // 设置多行输入框的推荐列数

area.setPrefRowCount(3); // 设置多行输入框的推荐行数

hbox.getChildren().addAll(label, area); // 给水平箱子添加一个多行输入框

borderPane.setCenter(hbox); // 把水平箱子放到边界窗格的中央

}

});

flowPane.getChildren().add(btn3); // 往流式窗格上添加按钮

运行包含以上测试代码的应用程序,单击按钮后的窗口界面如下图所示,可见TextArea的确支持输入多行文本。

51cc99512491d939fbfa6e5843d41ec0.png

继续在多行输入框中填写文字,一旦文字总高度超过输入框的高度,输入框右侧就会自动显示滚动条,此时窗口界面如下图所示。

85c3d3e1bbd523af8b7771cb25326f00.png

由图示可见JavaFX的TextArea默认集成了滚动条控件,无需像Swing的JTextArea那样得程序员手工操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值