代码部分
package com.tet.client;
import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.RootPanel;
/**
* Entry point classes define onModuleLoad().
*/
public class Zftet implements EntryPoint {
@Override
public void onModuleLoad() {
Button button = new Button("java调用内部jsni的js方法");
button.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
// gwt中java调用js方法
execute("js方法被调用");
}
});
Button button1 = new Button("内部jsni的js调用java方法");
button1.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
// gwt中java调用js方法
executeJs("java方法被调用");
}
});
Button button2 = new Button("JAVA调用外部js");
button2.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
// gwt中java调用js方法
callOutJS("外部js被调用");
}
});
logout();
outJsCallGwt();
outJsCallGwt1();
RootPanel.get().add(button);
RootPanel.get().add(button1);
RootPanel.get().add(button2);
}
private static native void SetWPPic(String xx) /*-{
top.SetWPPic(xx);
}-*/;
/**
* JSNI方法 调用外部js方法
*
* @param id
*/
public static native void callOutJS(String str) /*-{
$wnd.callOutJs(str);
}-*/;
/**
* JSNI方法
*
* @param id
*/
public static native void execute(String str) /*-{
alert(str);
}-*/;
/**
* JSNI方法, 里面调用java方法 javaAlert
*
* @param id
*/
public static native void executeJs(String str) /*-{
@com.tet.client.Zftet::javaAlert(Ljava/lang/String;)(str);
}-*/;
native void logout() /*-{
$wnd.logout = function() {
@com.tet.client.Zftet::test()();
};
}-*/;
static void test() {
Window.alert("++++");
}
static void test(String value) {
Window.alert(value);
}
/**
* 被js方法调用
*
* @param id
*/
public static void javaAlert(String str) {
Window.alert(str);
}
/**
* 需要被调用的js方法
*
* @param id
*/
private static native void outJsCallGwt() /*-{
$wnd.outJsCallGwt = function(str) {
alert("此处是gwt:" + str);
};
}-*/;
/**
* 需要被调用的js方法
*
* @param id
*/
private static native void outJsCallGwt1() /*-{
$wnd.outJsCallGwt1 = function(str) {
@com.tet.client.Zftet::test(Ljava/lang/String;)(str)();
};
}-*/;
}
HTML 页面
<!doctype html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link type="text/css" rel="stylesheet" href="Zftet.css">
<title>Web Application Starter Project</title>
<script type='text/javascript'>
function WPSelectPic() {
window.external.notify("wp");
}
function SetWPPic(url) {
document.getElementById('File1').value = url;
window.alert(url);
}
function getActivityID() {
var id = "a6940e1e-fbbb-4fae-a233-9451e0854fc8";
return id;
}
</script>
<script type='text/javascript'>
function callOutJs(str) {
alert('此处是外部js方法:' + str);
}
</script>
<script type="text/javascript" language="javascript"
src="zftet/zftet.nocache.js"></script>
</head>
<!-- -->
<!-- The body can have arbitrary html, or -->
<!-- you can leave the body empty if you want -->
<!-- to create a completely dynamic UI. -->
<!-- -->
<body>
<!-- OPTIONAL: include this if you want history support -->
<iframe src="javascript:''" mce_src="javascript:''"
id="__gwt_historyFrame" tabIndex='-1'
style="position: absolute; width: 0; height: 0; border: 0"></iframe>
<!-- RECOMMENDED if your web app will not function without JavaScript enabled -->
<noscript>
<div
style="width: 22em; position: absolute; left: 50%; margin-left: -11em; color: red; background-color: white; border: 1px solid red; padding: 4px; font-family: sans-serif">
Your web browser must have JavaScript enabled in order for this
application to display correctly.</div>
</noscript>
<h1>Web Application Starter Project</h1>
<table align="center">
<tr>
<td colspan="2" style="font-weight: bold;"
mce_style="font-weight:bold;">Please enter your name:</td>
</tr>
<tr>
<button onclick="outJsCallGwt('外部按钮被点击')">点击1</button>
<button onclick="outJsCallGwt1('外部按钮被点击')">点击2</button>
<a href='javascript:;' onclick='logout()'>注销</a>
<td id="nameFieldContainer"></td>
<td id="sendButtonContainer"></td>
</tr>
<tr>
<td colspan="2" style="color: red;" mce_style="color:red;"
id="errorLabelContainer"></td>
</tr>
</table>
</body>
</html>
分享到:
相关推荐
Google Web Toolkit(GWT)是一个开放源代码的Java框架,它允许开发者使用Java语言来编写富互联网应用程序(Rich Internet Applications,RIA),并将其编译成优化的JavaScript代码,从而在浏览器中运行。GWT的主要...
- **跨平台兼容性**: GWT编译器能够将Java代码转换为浏览器兼容的JavaScript和HTML代码。 - **高性能**: 通过高效的编译器优化,GWT可以生成高性能的前端代码。 - **易于开发**: 开发者可以直接使用熟悉的Java...
- **序列化**:GWT不支持标准JAVA序列化,但提供了RPC机制,实现远程方法调用时的对象自动序列化。 **跨浏览器支持** GWT设计为跨浏览器兼容,允许在单一代码基础上支持多种浏览器,减少了处理浏览器兼容性问题的...
Java到JavaScript转换工具有助于开发者将已有的Java代码库移植到JavaScript环境中,这在Web开发中尤其有用,因为JavaScript是浏览器端的主要脚本语言。这样的工具能够帮助开发者利用Java的强大功能来构建前端应用,...
在GWT(Google Web Toolkit)开发中,XMLHttpRequest(XHR)是实现客户端与服务器间异步数据交换的关键技术。GWT提供了对XHR的封装,使得开发者可以方便地使用JavaScript的XMLHttpRequest对象,而无需直接接触底层的...
1. **Java Applet**:早期的一种方式是使用Java Applet,它是一种嵌入在HTML页面中的小程序,允许JavaScript调用Java方法。然而,由于安全问题和现代浏览器对Flash及Applet的支持逐渐减少,这种方式已不再推荐。 2....
GWT允许开发者使用Java语言编写客户端代码,然后通过编译器将其转换为优化过的JavaScript,以便在各种浏览器上运行。这个“gwt 练习 gwt学习”项目可能是为了帮助用户熟悉GWT的基本概念、开发流程和最佳实践。 在...
- **序列化**:GWT不支持标准Java序列化,而是提供了一个RPC机制来进行远程方法调用时的自动对象序列化。 #### 八、跨浏览器支持 - GWT的设计考虑到了跨浏览器的兼容性问题,使得开发者能够专注于应用程序的开发而...
更重要的是,GWT提供了一套编译工具,能够将Java代码编译成对应的Ajax应用,其中涉及到的服务器交互会自动生成异步调用代码,大大降低了开发难度,加速了开发流程。 #### GWT的关键特性 1. **GWT编译器**:GWT的...
GWT通过Java语言进行开发,并将Java代码编译成高效的JavaScript,使得开发者可以利用Java的强大特性和丰富的库来创建复杂的Web应用,同时避免了直接编写JavaScript的繁琐和兼容性问题。 **GWT 的核心概念** 1. **...
综上所述,"gwt+spring+hibernate"的整合旨在展示如何在Java Web应用中同时利用GWT的富客户端特性、Spring的架构优势和Hibernate的数据持久化能力。通过这样的整合,开发者可以构建出用户体验良好、业务逻辑清晰且...
4. **集成EXTJS**:若要使用EXTJS库,需将EXTJS库文件复制到项目的public/js/ext目录,并在GWT模块配置文件中指定引入。 5. **编写Java代码**:使用GWT的API编写Java代码,包括用户界面组件和业务逻辑。GWT的编译器...
9. **自动RPC服务**:GWT的Remote Procedure Call (RPC)机制能自动处理Java对象与服务器端的通信,简化服务调用。 总之,GWT通过将Java与Ajax相结合,降低了开发复杂性,提高了开发速度,同时也确保了应用的质量和...
GWT的核心理念是通过Java编译器将Java代码转换为高性能的JavaScript,从而在浏览器环境中运行。这样,开发者可以利用强大的Java生态系统,同时避免直接与JavaScript的复杂性打交道。 **GWT的主要特点:** 1. **...
GWT是一个开源的开发工具,允许开发者使用Java语言来编写客户端的Web应用程序,然后将其编译为优化过的JavaScript代码,以实现高性能的富互联网应用(RIA)。而Ext Js是一个JavaScript库,提供了丰富的用户界面组件...
【标题】:“GWT反射”是指在Google Web Toolkit (GWT)环境中利用Java的反射机制来操作类和对象的一种技术。GWT是一个开源框架,它允许开发者使用Java语言编写客户端Web应用,然后编译成高效的JavaScript代码运行在...
- **Hosted Model**:在开发过程中,GWT 提供了 Hosted Mode,它模拟一个浏览器环境,让开发者可以直接在 Java 虚拟机上运行和调试 Java 代码,无需每次都编译成 JavaScript。这种方式提高了开发效率,便于调试。 ...
1. **Java到JavaScript的编译**:GWT编译器将Java代码转化为高效的JavaScript,使得开发者可以用Java进行前端开发。 2. **代码分割**:为了提高加载速度,GWT支持按需加载部分代码,用户只需下载他们实际使用的功能...
在这种情况下,GWT 支持 JavaScript Native Interface (JSNI),允许开发者直接在 Java 代码中嵌入 JavaScript 代码。这种机制为开发者提供了极大的灵活性,使其能够在需要时使用原生 JavaScript 功能。 #### 二、用...