快速提示:使用Chrome开发工具调试GWT应用程序

调试是软件开发的重要方面。 拥有正确的工具可以节省大量时间和头痛。 在GWT Super Dev模式之前,经典的Dev模式允许使用JVM调试。 开发人员可以在其IDE中设置断点,并使用调试模式来跟踪错误和错误。 现在,在超级开发模式下,情况有所不同。 整个应用程序都已编译并在浏览器中运行,因此无法再使用JVM调试。 想到的问题是:是否可以在浏览器中调试Java? 幸运的是,答案是肯定的。
原则上,浏览器只能运行和调试javascript。 为了克服此缺点,引入了源地图。 源图充当从源语言到目标语言的映射的蓝图。 源映射可以用于多种语言,甚至可以在最小化和未最小化的javascript之间进行映射。 在本文中,我们将使用源地图和Chrome开发工具来调试应用程序错误。 我们将以遇到运行时错误的Polymer-starter-kit为例。 错误如下

该错误不会破坏应用程序,但重要的是要知道导致它的原因。

没有源图:

如果我们尝试在不启用源映射的情况下访问源代码,则将无法在源代码中指出错误发生的位置。

启用源地图:

为了克服这个问题,我们需要激活源地图。 可以在Chrome上通过转到设置->源->启用JavaScript源地图来激活源地图。 通常,默认情况下,源映射是由GWT编译器生成的。 如果没有,在.gwt.xml中设置以下属性可以激活它们:

启用断点后,我们可以看到该错误现在指向.java文件而不是.js文件:

设置断点:

现在我们看到了错误发生的位置,我们可以设置一个断点来检查应用程序的状态。 可以通过在编辑器中单击行号来简单地设置断点。

跟踪错误:

最后,我们可以刷新应用程序。 到达断点时,应用程序将停止。 然后,我们可以检查调用堆栈和变量值。

现在我们知道错误完全在代码中发生了。 我们可以检查我们是否滥用了声明。 在这种情况下,删除无用的这一行就足够了。

使用Chrome工作区(可选)

Chrome工作区允许将浏览器加载的文件映射到磁盘上的文件,并直接对Chrome中的文件进行更改。 如果不需要IDE辅助并且不想从浏览器到IDE来回切换,这将很有用。 要使用Chrome工作区,您可以右键单击左侧“源”选项卡上的空白处,然后单击“将文件夹添加到工作区”。 然后,您可以右键单击打开的文件,然后单击“映射到文件系统资源”。 有关更多信息,请访问: https : //developers.google.com/web/tools/setup/setup-workflow

包起来:

使用源映射在浏览器中调试GWT应用可以节省大量时间,并有助于正确跟踪错误。 Chrome Dev工具提供了功能强大的调试工具,可以帮助提高生产率并快速解决错误。 Chrome开发工具提供了更高级的调试功能,例如调试HTTP请求和DOM更改,如果您想浏览这些请求,可以转到Google的用户指南: https : //developers.google.com/web/tools/ chrome-devtools / javascript / breakpoints

值得一看的: DevTools:2017年国际联盟(Google I / O '17)

翻译自: https://www.javacodegeeks.com/2017/07/quick-tip-debugging-gwt-application-using-chrome-dev-tools.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349261.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用matlab做纹理合成,关于图像纹理合成的Matlab例程

纹理是普遍存在的视觉现象,其可以描述地形、植物、矿石、纤维和皮肤等等物体的表面特征。纹理结构在图像中反映其图像像素取值的空间变化情况,这种变化具有某中统计规律,在纹理区域内的各部分具有大致相同的结构。纹理合成是利用计算机产生纹…

python 服务端与c++客户端通讯_[原创]python socket 服务端 与 c++客户端通讯,发包内容加密,支持大文件,并发...

代码经过网络搜索,综合算是原创吧.py脚本为服务端项目文件在https://github.com/jinjie412/service_client_socketimport socketserverimport jsonimport base64import osfrom te import OPMysql,Caltimeimport time#数据库操作opm OPMysql()#加密发包内容def crypt(source,ke…

matlab评估边缘检测性能,【模糊推理】模糊逻辑图像边缘检测,原理+matlab代码~...

这篇博客是接着上一篇来哒,https://blog.csdn.net/luolan9611/article/details/94285158本篇博客及上篇博客搜集的资料、实验代码、实验报告、PPT均已上传至百度网盘:链接:https://pan.baidu.com/s/1AmT4TtBAxj1FKf4KUFcsBw 提取码&#x…

qt中实现左右分割线_Qt项目中,实现屏幕截图并生成gif的详细示例(值得细读)...

总第50篇平时我们在工作和学习的过程中,有时需要将桌面的某些动作截图生成gif动图,以更生动地呈现出来。目前有很多这样的软件,并且方便易使用,比如我经常使用的GifCam,软件小巧,生成的图片文件也比较小&am…

构建Spring Boot RESTful服务+ Spring Boot执行器

总览 什么是REST? REST(代表状态转移)是Web构建的体系结构样式,已成为用于Web应用程序的标准软件设计模式 。 代表性国家转移一词最早由REST的发起人,HTTP规范的主要作者之一Roy Fielding在其博士论文中使用 。 REST上…

matlab 安装glpk,mac上安装GLPK

Obsolation note:Thanks to Dave Coleman’s comment I found out that glpk is available through homebrew now! So you just need these 2 steps to get glpk now:homebrewbrew install glpkIf you still want to read on, the old way is still here…So you want copy-pas…

tf调不到keras怎么 回事_格力变频空调快速维修方法及技巧 空调压缩机不到一分钟就停,怎么回事?...

格力变频空调快速维修方法及技巧一、 室内部分: 1、F1开路:制冷时不启动或启动一下就停机;制热正常,且一直高频运转。 2、F2开路:工作6—10分钟就停机,显示E2停止外机。 3、F2短路&#xff1…

php 档案,PHP 档案包 (PHAR)

PHP 档案包 (PHAR)要获取 PHPUnit,最简单的方法是下载 PHPUnit 的 PHP 档案包 (PHAR),它将 PHPUnit 所需要的所有必要组件(以及某些可选组件)捆绑在单个文件中:要使用 PHP档案包(PHAR)需要有 phar 扩展。要使用 PHAR 的 --self-update 功能需…

pycharm是不是python编程_使用PyCharm进行python开发的简介

使用PyCharm进行python开发的简介这个是很常见的一个问题,我想学习python,用什么编辑器呢?eclipsepydev?IDLE?vim?每个人有自己的习惯,可能是自己琢磨的,也可能是前辈指导的,这里只分享自己孤陋寡闻琢磨…

php自动释放mysql连接,php怎么关闭mysql连接

php怎么关闭mysql连接2021-03-17 07:45:43php中可使用mysqli_close()函数来关闭mysql连接,语法格式“mysqli_close(connection);”。mysqli_close()函数可关闭先前打开的数据库连接,如果成功返回TRUE,反之则返回FALSE。本教程操作环境&#x…

Java 8 –按值对HashMap进行升序和降序排序

在上一篇文章中,我向您展示了如何通过键对Java 8中的Map进行排序 ,今天,我将教您如何使用Java 8功能(例如,lambda表达式,方法引用,流和新方法) 按值对Map进行排序。添加到java.util.…

python处理wps表格数据匹配_WPS表格技巧—如何利用WPS表格实现数据分组

小伙伴们在工作中经常会遇到这种情况,密密麻麻的数据看着都让人眼晕,处理起来更是费劲,稍不留心,就看错了,为了使数据看起来更有条理性,有的小伙伴常常会用筛选的功能实现数据之间的互换和操作。但是却很少…

scrcpy投屏_scrcpy 使用教程:将安卓设备投屏到 PC 端

阿拉平平读完需要6分钟速读仅需 2 分钟scrcpy 是一款开源的安卓设备投屏工具,通过 USB 或 Wi-Fi 与设备连接后就可以在 PC 端操作安卓设备,无需 root 权限且支持多平台运行。本文将演示如何使用 scrcpy 进行投屏操作。1. 下载安装到 Releases 下载最新的…

javap的用途不断发展:您的Java类文件中隐藏了什么?

什么是Javap,如何使用它以及何时要反汇编类文件? 作为Java开发工具包(JDK)的一部分,我们可以使用许多工具,这些工具有助于更好地理解Java代码。 这些工具之一是javap命令,它为我们提供了对Java…

打砖块小游戏php程序,利用原生js实现html5打砖块小游戏(代码示例)

本篇文章给大家通过代码示例介绍一下利用原生js实现html5打砖块小游戏的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。前言PS:本次项目中使用了大量 es6 语法,故对于 es6 语法不太熟悉的小伙伴最好能先了…

si9000阻抗匹配计算_如何在设计之初计算出两层PCB板差分线的阻抗,线宽,间距...

最近在设计一款两层板PCB。板上一些高速信号线,分别是MIMP接口的差分线和USB2.0的差分线。既然是高速线,那么就需要设计成阻抗匹配走线。MIMP差分线需要做100ohm匹配,USB线需要做90ohm匹配。差分线阻抗的计算主要跟线宽,间距&…

oracle查询排序速度慢,Oracle-请问Oracle SQL排序查询慢如何解决

这个原因很简单&#xff1a;SELECT * FROM(SELECT T.*,ROWNUM RN FROM(SELECT * FROM INFO ORDER BY PDATE DESC) T WHERE ROWNUM<2001) WHERE RN>0算一下&#xff0c;如果使用定义在PDATE上的索引&#xff0c;那么拿到这2000个rowid后&#xff0c;还需要做2000次random …

jax-ws cxf_Apache CXF – JAX-WS –简单教程

jax-ws cxf许多Java开发人员都认为Web Service实现的任务艰巨-好吧&#xff0c;没有人能真正责怪他们&#xff0c;尤其是在企业应用程序开发的多年中&#xff0c;这给开发和设计带来了很多复杂性。 对于某些人来说&#xff0c;了解它是构建完整的企业应用程序的下一步-Web服务-…

oracle instance client 下载,安装Oracle Instance Client

不想再装客户端了&#xff0c;个太大了。1、去下载你想要的Instance Clent版本&#xff0c;解压&#xff1b;2、把以前备份的sqlnet.oratnsnames.ora放在解压后的目录&#xff1b;3、配置环境变量变量名:TNS_ADMIN变量值:X:\XXXXXXXX\instantclient_10_24、用记事本保存为XX.re…

写屏障是什么_面试官为什么问内存模型总离不开final关键字,该如何应对?

Java 语言的每个关键字都设计的很巧妙&#xff0c;金雕玉琢&#xff0c;只有深度钻研其中&#xff0c;才知其中懊悔&#xff0c;本文带领大家一起深入理解 Java 内存模型之 final。加我微信好友的不要着急&#xff0c;手机没电了&#xff0c;等我借个充电器之后&#xff0c;再一…