`
zf0512305
  • 浏览: 7494 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

gwt中 java、js互相调用

    博客分类:
  • gwt
gwt 
阅读更多
代码部分
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>

分享到:
评论

相关推荐

    GWT开发环境JAVA

    Google Web Toolkit(GWT)是一个开放源代码的Java框架,它允许开发者使用Java语言来编写富互联网应用程序(Rich Internet Applications,RIA),并将其编译成优化的JavaScript代码,从而在浏览器中运行。GWT的主要...

    GWT快速开发(GWT) 是一个Java软件开发框架用于开发类似于Google Maps和Gmail的AJAX应用程序。GWT的设计参考Java AWT包设计,类命名规则、接口设计、事件监听等。你可以用Java编程语言开发你的界面,然后用GWT编译器将Java类转换成适合浏览器执行的...

    - **跨平台兼容性**: GWT编译器能够将Java代码转换为浏览器兼容的JavaScript和HTML代码。 - **高性能**: 通过高效的编译器优化,GWT可以生成高性能的前端代码。 - **易于开发**: 开发者可以直接使用熟悉的Java...

    GWT开发者手册 GWT开发者手册

    - **序列化**:GWT不支持标准JAVA序列化,但提供了RPC机制,实现远程方法调用时的对象自动序列化。 **跨浏览器支持** GWT设计为跨浏览器兼容,允许在单一代码基础上支持多种浏览器,减少了处理浏览器兼容性问题的...

    java转js工具

    Java到JavaScript转换工具有助于开发者将已有的Java代码库移植到JavaScript环境中,这在Web开发中尤其有用,因为JavaScript是浏览器端的主要脚本语言。这样的工具能够帮助开发者利用Java的强大功能来构建前端应用,...

    GWT中的xmlHttpRequest

    在GWT(Google Web Toolkit)开发中,XMLHttpRequest(XHR)是实现客户端与服务器间异步数据交换的关键技术。GWT提供了对XHR的封装,使得开发者可以方便地使用JavaScript的XMLHttpRequest对象,而无需直接接触底层的...

    Java和JavaScript库进行交互

    1. **Java Applet**:早期的一种方式是使用Java Applet,它是一种嵌入在HTML页面中的小程序,允许JavaScript调用Java方法。然而,由于安全问题和现代浏览器对Flash及Applet的支持逐渐减少,这种方式已不再推荐。 2....

    gwt 练习 gwt学习

    GWT允许开发者使用Java语言编写客户端代码,然后通过编译器将其转换为优化过的JavaScript,以便在各种浏览器上运行。这个“gwt 练习 gwt学习”项目可能是为了帮助用户熟悉GWT的基本概念、开发流程和最佳实践。 在...

    GWT开发者手册 GWT

    - **序列化**:GWT不支持标准Java序列化,而是提供了一个RPC机制来进行远程方法调用时的自动对象序列化。 #### 八、跨浏览器支持 - GWT的设计考虑到了跨浏览器的兼容性问题,使得开发者能够专注于应用程序的开发而...

    入门学习GWT

    更重要的是,GWT提供了一套编译工具,能够将Java代码编译成对应的Ajax应用,其中涉及到的服务器交互会自动生成异步调用代码,大大降低了开发难度,加速了开发流程。 #### GWT的关键特性 1. **GWT编译器**:GWT的...

    GWT Demo,GWT学习时的一些小例子

    GWT通过Java语言进行开发,并将Java代码编译成高效的JavaScript,使得开发者可以利用Java的强大特性和丰富的库来创建复杂的Web应用,同时避免了直接编写JavaScript的繁琐和兼容性问题。 **GWT 的核心概念** 1. **...

    gwt+spring+hibernate

    综上所述,"gwt+spring+hibernate"的整合旨在展示如何在Java Web应用中同时利用GWT的富客户端特性、Spring的架构优势和Hibernate的数据持久化能力。通过这样的整合,开发者可以构建出用户体验良好、业务逻辑清晰且...

    GWT 开发和部署文档

    4. **集成EXTJS**:若要使用EXTJS库,需将EXTJS库文件复制到项目的public/js/ext目录,并在GWT模块配置文件中指定引入。 5. **编写Java代码**:使用GWT的API编写Java代码,包括用户界面组件和业务逻辑。GWT的编译器...

    GWT入门及用例文档

    9. **自动RPC服务**:GWT的Remote Procedure Call (RPC)机制能自动处理Java对象与服务器端的通信,简化服务调用。 总之,GWT通过将Java与Ajax相结合,降低了开发复杂性,提高了开发速度,同时也确保了应用的质量和...

    gwt-jar.rar

    GWT的核心理念是通过Java编译器将Java代码转换为高性能的JavaScript,从而在浏览器环境中运行。这样,开发者可以利用强大的Java生态系统,同时避免直接与JavaScript的复杂性打交道。 **GWT的主要特点:** 1. **...

    Gwt-Ext学习笔记之进级篇

    GWT是一个开源的开发工具,允许开发者使用Java语言来编写客户端的Web应用程序,然后将其编译为优化过的JavaScript代码,以实现高性能的富互联网应用(RIA)。而Ext Js是一个JavaScript库,提供了丰富的用户界面组件...

    GWT反射

    【标题】:“GWT反射”是指在Google Web Toolkit (GWT)环境中利用Java的反射机制来操作类和对象的一种技术。GWT是一个开源框架,它允许开发者使用Java语言编写客户端Web应用,然后编译成高效的JavaScript代码运行在...

    gwt入门-gwt从这里开始

    - **Hosted Model**:在开发过程中,GWT 提供了 Hosted Mode,它模拟一个浏览器环境,让开发者可以直接在 Java 虚拟机上运行和调试 Java 代码,无需每次都编译成 JavaScript。这种方式提高了开发效率,便于调试。 ...

    gwt揭秘源代码

    1. **Java到JavaScript的编译**:GWT编译器将Java代码转化为高效的JavaScript,使得开发者可以用Java进行前端开发。 2. **代码分割**:为了提高加载速度,GWT支持按需加载部分代码,用户只需下载他们实际使用的功能...

    GWT安装和使用

    在这种情况下,GWT 支持 JavaScript Native Interface (JSNI),允许开发者直接在 Java 代码中嵌入 JavaScript 代码。这种机制为开发者提供了极大的灵活性,使其能够在需要时使用原生 JavaScript 功能。 #### 二、用...

Global site tag (gtag.js) - Google Analytics