我试图在JavaFX中获得一个TableView来动态显示内容。
当我运行程序时,出现以下错误:
java.lang.ClassNotFoundException: UserInterfaceController
我的控制器名为“UserInterfaceController.java”,它与FXML文件在同一个包下,我也在FXML中导入了包。为什么找不到控制器?
FXML文件:
<?import javafx.collections.*?>
<?import javafx.geometry.Insets?>
<?import java.lang.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.control.cell.*?>
<?import javafx.scene.layout.*?>
<?import d1example2.*?>
<GridPane alignment="center" hgap="10.0" vgap="10.0" fx:controller="UserInterfaceController"
xmlns:fx="http://javafx.com/fxml">
<TableView fx:id="tableView" GridPane.columnIndex="0" GridPane.rowIndex="1">
<columns>
</columns>
</TableView>
</GridPane>
控制器:
package d1example2;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.ResourceBundle;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.value.ObservableValue;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableColumn.CellDataFeatures;
import javafx.scene.control.TableView;
import javafx.scene.control.TextField;
import javafx.scene.control.cell.PropertyValueFactory;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.AnchorPane;
import javafx.scene.text.Text;
import javafx.util.Callback;
public class UserInterfaceController implements Initializable {
private Label label;
@FXML
private AnchorPane MainPane;
@FXML
private TextField FirstField;
@FXML
private Text TimesText;
@FXML
private Text EqualSign;
@FXML
private Text EquationResult;
@FXML
private TableColumn<?, ?> HalfColumn;
@FXML
private TableColumn<?, ?> DoubleColumn;
@FXML
private Button SubmitButton;
@FXML private TableView tableView;
@FXML
public void initialize(URL url, ResourceBundle rb) {
List<String> columns = new ArrayList<String>();
columns.add("col1");
columns.add("col2");
TableColumn [] tableColumns = new TableColumn[columns.size()];
int columnIndex = 0;
for(int i=0 ; i<columns.size(); i++) {
final int j = i;
TableColumn col = new TableColumn(columns.get(i));
col.setCellValueFactory(new Callback<CellDataFeatures<ObservableList,String>,ObservableValue<String>>(){
public ObservableValue<String> call(CellDataFeatures<ObservableList, String> param) {
return new SimpleStringProperty(param.getValue().get(j).toString());
}
});
tableView.getColumns().addAll(col);
}
ObservableList<String> row = FXCollections.observableArrayList();
ObservableList<String> row1 = FXCollections.observableArrayList();
row.addAll("d1");
row.addAll("d11");
row1.addAll("d2");
row1.addAll("d22");
tableView.getItems().add(row);
tableView.getItems().add(row1);
}
@FXML
private void handleButtonAction(MouseEvent event) {
}
}
主要类:
package d1example2;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.layout.Pane;
import javafx.stage.Stage;
public class D1Example2 extends Application {
@Override
public void start(Stage primaryStage) throws Exception {
primaryStage.setTitle("FXML TableView Example");
Pane myPane = (Pane)FXMLLoader.load(getClass().getResource("UserInterface.fxml"));
Scene myScene = new Scene(myPane);
primaryStage.setScene(myScene);
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
使用完全限定名从FXML引用控制器:
fx:controller="d1example2.UserInterfaceController"
后续问题的答案
以下问题的答案解释了为什么会这样,但如果你不想,你不一定需要理解为什么,以下纯粹是信息性的。
他有进口对账单,为什么一定要完全合格?
解析FXML控制器类时,不会搜索FXML文件中的导入。控制器类类型是通过类加载器找到的(我是通过阅读JavaFXFXMLLoader源代码确定的)。类加载器需要一个完全限定的名称(根据Java语言规范,具体来说是一个二进制名称)。
找到类型后,如果没有为fhtml" target="_blank">xml加载指定控制器工厂,则FXMLLoader将使用反射实例化控制器本身,否则它将将该作业委托给适当的控制器工厂(例如,基于Spring依赖注入关联控制器实例的控制器工厂),但即使在该实例中,也必须首先由FXMLLoader找到并确定适当的类型,并且为此需要控制器的完全限定类名。
如果我需要这样做,导入语句的意义是什么?
import语句用于解析与文档中FXML元素对应的Java类型。这样,文档可以包含以下行:
<?import javafx.scene.layout.*?>
您可以只引用GridPane而不是javafx。场景布局GridPane,当您想在FXML中定义新的GridPane时。
<GridPane alignment="center" ...>
是的,有可能,FXMLLoader也可以被编码为以同样的方式解析控制器类,但在编写此答案时还没有这样编写。
在创建资源类和指定资源格输出式化后, 下一步就是创建控制器操作将资源通过 RESTful APIs 展现给终端用户。 Yii 提供两个控制器基类来简化创建 RESTful 操作的工作:yii\rest\Controller 和 yii\rest\ActiveController, 两个类的差别是后者提供一系列将资源处理成 Active Record 的操作。 因此如果使用 Active Recor
控制器是 MVC 模式中的一部分, 是继承yii\base\Controller类的对象,负责处理请求和生成响应。 具体来说,控制器从应用主体 接管控制后会分析请求数据并传送到模型, 传送模型结果到视图,最后生成输出响应信息。 动作 控制器由 操作 组成,它是执行终端用户请求的最基础的单元, 一个控制器可有一个或多个操作。 如下示例显示包含两个动作view and create 的控制器post:
简介 为了替代把所有的请求处理逻辑都定义在 routes.php 路由文件中,你或许想要使用控制来组织这些行为。控制器可以把相关的请求处理逻辑整合为一个控制器类。控制器类文件被存储在 app/Http/Controllers 目录下。 基础控制器 这里有一个基础控制器的示例。所有 Lumen 的控制器都应该继承 Lumen 安装时内置的默认的控制器基类: <?php namespace App\
简介 为了代替在路由文件中以闭包的形式定义所有的请求处理逻辑,你也许想使用控制类来组织这些行为。控制器能够将相关的请求处理逻辑组成一个单独的类,控制器被存放在 app/Http/Controllers 目录下。 基础控制器 定义控制器 下面是一个基础控制器类的例子。需要注意的是,该控制器继承了一个Laravel内置的基础控制器类。该基础控制器提供了一些编辑的方法,比如 middleware 方法,
ThinkCMF目前分为两种控制器,前台和后台控制器; 无论是前台,还是后台控制器都位于应用的Controller目录下. 前台控制器一般继承 Common\Controller\HomebaseController,如果你需要用户登录才访问或操作此控制器,就要继承 Common\Controller\MemberbaseController; 我们来创建一个前台控制器: 在Blog应用Contr
控制器文件默认放在 app/modules/{module}/actions 文件夹。 控制器的文件命名格式为 XxxxAction.class.php, 所有的控制器都必须继承基类控制器 herosphp\core\Controller, 基类控制器是抽象类: abstract class Controller extends Template { /** * 视图模板名称
Kubernetes中内建了很多controller(控制器),这些相当于一个状态机,用来控制Pod的具体状态和行为。
控制器 通过执行 sudo mn --controller=remote --ip=[controller IP] --port=[controller listening port] 可以连接到控制器。