- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 Android 应用程序中,我通过覆盖从 Assets 加载本地 html 文件的 WebView 的 URL 加载来启动一个新的 Activity。当我单击 Android 设备上的后退按钮以使用 WebView 返回 Activity 时,WebView 现在显示消息“网页不可用”,并引用先前的 Activity 作为它试图加载的“网页”,例如file:///android_asset/com.example.myproject.BackButtonActivity 而不是 file:///android_asset/example.html
在 Activity 的 onCreate 方法中使用以下代码设置 WebView:
this.webView = (WebView)findViewById(R.id.webview);
this.webView.loadUrl("file:///android_asset/example.html");
WebViewClient webViewClient = new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
if (url.contains("start.back.button.activity")) {
Intent intent = new Intent(getBaseContext(), BackButtonActivity.class);
startActivity(intent);
return false;
}
view.loadUrl(url);
return true;
}
};
this.webView.setWebViewClient(webViewClient);
当包含 WebView 的 Activity 首次显示时,一切都会正确显示。我可以单击该链接并启动新的 Activity。但是,当我单击设备后退按钮时,WebView 会查找具有前一个 Activity 类名称的 Assets ,而不是原始文件,并且无法正确加载。
任何关于为什么会发生这种情况的想法以及任何可能的修复将不胜感激。
这是从按下后退按钮到显示包含 WebView 的 Activity 时的 logcat 输出:
02-28 02:58:39.218 9291-9317/com.example.myproject V/webcore﹕ 230 arg1=1 arg2=0 obj=null
02-28 02:58:39.231 9291-9317/com.example.myproject V/webcore﹕ 230 arg1=0 arg2=0 obj=null
02-28 02:58:39.243 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x61230760) (w:480, h:782, f:1)
02-28 02:58:39.245 9291-9291/com.example.myproject D/GraphicBuffer﹕ close handle(0x61230760) (w:480 h:782 f:1)
02-28 02:58:39.246 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x61230760) (w:480, h:782, f:1)
02-28 02:58:39.248 9291-9317/com.example.myproject V/webcore﹕ SET_ACTIVE arg1=1 arg2=0 obj=null
02-28 02:58:39.248 9291-9291/com.example.myproject V/InputMethodManager﹕ onWindowFocus: android.webkit.WebView{41d02530 VFEDHVCL .F....ID 0,0-480,672 #7f0d001f app:id/activity_mywebview} softInputMode=16 first=true flags=#1810100
02-28 02:58:39.248 9291-9291/com.example.myproject D/webview﹕ onCreateInputConnection
02-28 02:58:39.248 9291-9291/com.example.myproject D/WebViewInputConnection﹕ resetBatchLevel mBatchLevel = 0
02-28 02:58:39.248 9291-9291/com.example.myproject V/InputMethodManager﹕ START INPUT: android.webkit.WebView{41d02530 VFEDHVCL .F....ID 0,0-480,672 #7f0d001f app:id/activity_mywebview} ic=android.webkit.WebViewClassic$WebViewInputConnection@41d2e148 tba=android.view.inputmethod.EditorInfo@41d1fb68 controlFlags=#105
02-28 02:58:39.251 9291-9291/com.example.myproject V/InputMethodManager﹕ Starting input: Bind result=InputBindResult{com.android.internal.view.IInputMethodSession$Stub$Proxy@41d1fc68 com.htc.sense.ime/.HTCIMEService #2861}
02-28 02:58:39.267 9291-9325/com.example.myproject I/SurfaceTextureClient﹕ [STC::queueBuffer] (this:0x5eb9d4e0) fps:1.52, dur:12462.08, max:12084.30, min:5.31
02-28 02:58:39.267 9291-9325/com.example.myproject I/SurfaceTextureClient﹕ [STC::queueBuffer] this:0x5eb9d4e0, api:2, last queue time elapsed:12084.30
02-28 02:58:39.267 9291-9325/com.example.myproject I/BufferQueue﹕ [unnamed-9291-0](this:0x5eb9c5f0,api:2) [queue] fps:1.52, dur:12461.71, max:12084.44, min:5.32
02-28 02:58:39.269 9291-9291/com.example.myproject I/BufferQueue﹕ [unnamed-9291-0](this:0x5eb9c5f0,api:2) [release] fps:1.60, dur:12467.44, max:12075.28, min:6.18
02-28 02:58:39.288 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x5e3d6d70) (w:480, h:782, f:1)
02-28 02:58:39.289 9291-9291/com.example.myproject D/OpenGLRenderer﹕ Flushing caches (mode 0)
02-28 02:58:39.289 9291-9291/com.example.myproject D/GraphicBuffer﹕ close handle(0x5ed66d70) (w:480 h:782 f:1)
02-28 02:58:39.290 9291-9291/com.example.myproject D/GraphicBuffer﹕ close handle(0x5e3d6d70) (w:480 h:782 f:1)
02-28 02:58:39.296 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x5f38db68) (w:480, h:782, f:1)
02-28 02:58:39.604 9291-9291/com.example.myproject D/OpenGLRenderer﹕ Flushing caches (mode 0)
02-28 02:58:40.330 9291-9325/com.example.myproject I/SurfaceTextureClient﹕ [STC::queueBuffer] (this:0x5eb9d4e0) fps:3.76, dur:1063.85, max:1019.87, min:6.87
02-28 02:58:40.330 9291-9325/com.example.myproject I/BufferQueue﹕ [unnamed-9291-0](this:0x5eb9c5f0,api:2) [queue] fps:3.76, dur:1063.79, max:1019.96, min:6.88
02-28 02:58:40.436 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x5e3d5fd0) (w:480, h:782, f:1)
02-28 02:58:40.441 9291-9291/com.example.myproject I/BufferQueue﹕ [unnamed-9291-0](this:0x5eb9c5f0,api:2) [release] fps:3.41, dur:1171.79, max:1126.83, min:6.62
02-28 02:58:40.445 9291-9291/com.example.myproject I/SurfaceTextureClient﹕ [STC::queueBuffer] (this:0x5ed2bbc8) fps:1.68, dur:1188.10, max:1114.11, min:73.99
02-28 02:58:40.453 9291-9291/com.example.myproject D/GraphicBuffer﹕ create handle(0x5ed72be8) (w:480, h:782, f:1)
最佳答案
您需要更改 WebViewClient
的返回语句:
WebViewClient webViewClient = new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
if (url.contains("start.back.button.activity")) {
Intent intent = new Intent(getBaseContext(), BackButtonActivity.class);
startActivity(intent);
return true; // <--- Switch to true
}
//view.loadUrl(url); // <--- You don't need this line when returning false
return false; // <--- Switch to false
}
};
来自docs :
Returns true if the host application wants to handle the key event itself, otherwise return false
关于Android:后退按钮导致 WebView 查找错误的 Assets ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28771192/
我正在尝试使用 Spark 从 Cassandra 读取数据。 DataFrame rdf = sqlContext.read().option("keyspace", "readypulse
这是代码: void i_log_ (int error, const char * file, int line, const char * fmt, ...) { /* Get erro
我必须调试一个严重依赖 Gtk 的程序。问题是由于某些原因,在使用 GtkWindow 对象时开始出现许多运行时警告。问题是,即使 Gtk 提示严重错误,它也不会因这些错误而中止。我没有代码库的更改历
我正在尝试从已有效编译和链接的程序中检索二进制文件。我已经通过 GL_PROGRAM_BINARY_LENGTH 收到了它的长度。该文档说有两个实例可能会发生 GL_INVALID_OPERATION
我有一个托管在 Azure 环境中的服务。我正在使用控制台应用程序使用该服务。这样做时,我得到了异常: "The requested service, 'http://xxxx-d.yyyy.be/S
我有以下代码,它被 SEGV 信号杀死。使用调试器表明它被 main() 中的第一个 sem_init() 杀死。如果我注释掉第一个 sem_init() ,第二个会导致同样的问题。我试图弄清楚是什么
目前我正在编写一个应用程序(目标 iOS 6,启用 ARC),它使用 JSON 进行数据传输,使用核心数据进行持久存储。 JSON 数据由 PHP 脚本通过 json_encode 从 MySQL 数
我对 Xamarin.Forms 还是很陌生。我在出现的主页上有一个非常简单的功能 async public Task BaseAppearing() { if (UserID
这是我的代码的简化版本。 public class MainActivity extends ActionBarActivity { private ArrayList entry = new Arr
我想弄明白为什么我的两个 Java 库很难很好地协同工作。这是场景: 库 1 有一个类 A,其构造函数如下: public A(Object obj) { /* boilerplate */ } 在以
如果网站不需要身份验证,我的代码可以正常工作,如果需要,则在打印“已创建凭据”后会立即出现 EXC_BAD_ACCESS 错误。我不会发布任何内容,并且此代码是直接从文档中复制的 - 知道出了什么问题
我在使用 NSArray 填充 UITableView 时遇到问题。我确信我正在做一些愚蠢的事情,但我无法弄清楚。当我尝试进行简单的计数时,我得到了 EXC_BAD_ACCESS,我知道这是因为我试图
我在 UITableViewCell 上有一个 UITextField,在另一个单元格上有一个按钮。 我单击 UITextField(出现键盘)。 UITextField 调用了以下方法: - (BO
我有一个应用程序出现间歇性崩溃。崩溃日志显示了一个堆栈跟踪,这对我来说很难破译,因此希望其他人看到了这一点并能为我指出正确的方向。 基本上,应用程序在启动时执行反向地理编码请求,以在标签中显示用户的位
我开发了一个 CGImage,当程序使用以下命令将其显示在屏幕上时它工作正常: [output_view.layer performSelectorOnMainThread:@selector(set
我正在使用新的 EncryptedSharedPreferences以谷歌推荐的方式上课: private fun securePrefs(context: Context): SharedPrefe
我有一个中继器,里面有一些控件,其中一个是文本框。我正在尝试使用 jquery 获取文本框,我的代码如下所示: $("#").click(function (event) {}); 但我总是得到 nu
在以下场景中观察到 TTS 初始化错误,太随机了。 已安装 TTS 引擎,存在语音集,并且可以从辅助功能选项中播放示例 tts。 TTS 初始化在之前初始化和播放的同一设备上随机失败。 在不同的设备(
maven pom.xml org.openjdk.jol jol-core 0.10 Java 类: public class MyObjectData { pr
在不担心冲突的情况下,可以使用 MD5 作为哈希值,字符串长度最多为多少? 这可能是通过为特定字符集中的每个可能的字符串生成 MD5 哈希来计算的,长度不断增加,直到哈希第二次出现(冲突)。没有冲突的
我是一名优秀的程序员,十分优秀!