java内嵌html5浏览器_java浏览器的开发html显示异常,一定要内嵌浏览器吗

展开全部

java浏览器开发,其实很简单, 使用JavaFX的WebView组件即62616964757a686964616fe58685e5aeb931333431356132可.(支持html5); 也可以在swing里使用JFXPanel然后添加WebView;

效果图如下

732fc0e81619487c7b408e5c0982777c.gif参考代码如下(java8+win10 x64 编写,测试)

import javafx.application.Application;

import javafx.concurrent.Worker.State;

import javafx.geometry.Insets;

import javafx.scene.Scene;

import javafx.scene.control.*;

import javafx.scene.layout.*;

import javafx.scene.web.*;

import javafx.stage.Stage;

public class WebViewTest extends Application {

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage primaryStage) throws Exception {

//顶部

HBox hbox=new HBox(8);

Label labeAddr=new Label("地址");

TextField tfAddr = new TextField();

tfAddr.setMinWidth(500);

tfAddr.setText("http://www.baidu.com");

Button btnGo = new Button("Go转到");

Button btnGoBack=new Button("

Button btnH=new Button("->");

TextField tfSerch = new TextField();

Button btnSerch= new Button("捜");

hbox.getChildren().addAll(labeAddr,tfAddr,btnGoBack,btnH,btnGo,tfSerch,btnSerch);

hbox.setPadding(new Insets(5));

//中间

WebView wv = new WebView();

WebEngine we = wv.getEngine();

we.getLoadWorker().stateProperty().addListener((ob, ov, nv) -> {

if(nv==State.SCHEDULED) {

tfAddr.setText(we.getLocation());//

}

});

//底部

Label labelBottom = new Label();

labelBottom.textProperty().bind(we.getLoadWorker().messageProperty());//底下的信息显示

BorderPane root = new BorderPane();

root.setTop(hbox);

root.setCenter(wv);

root.setBottom(labelBottom);

Scene scene = new Scene(root, 900, 600);

primaryStage.setTitle("JavaFX 雪飞潇潇 web浏览器");

primaryStage.setScene(scene);

primaryStage.show();

btnGo.setOnAction(e -> {

we.load(tfAddr.getText().trim());

});

btnGoBack.setOnAction(e->{

we.executeScript("history.back()");//执行JavaScript,后退

});

btnH.setOnAction(e->{

we.executeScript("history.forward()");//执行JavaScript,前进

});

//搜索

btnSerch.setOnAction(e->{

we.load("https://www.baidu.com/s?wd="+tfSerch.getText());

});

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值