gpt4 book ai didi

javascript - WebViewClient onPageFinished 从未调用过

转载 作者:行者123 更新时间:2023-12-02 15:40:01 25 4
gpt4 key购买 nike

我在 S/O 上看过几篇类似的帖子,但找不到我的问题的答案。我正在尝试从 Web View 中获取 html,但无法触发“onPageFinished() 回调。我什至尝试在 WebChromeClient 上使用进度回调,但没有任何效果。neigh web 客户端或 web chrome 客户端收到任何回调。我正在将此代码作为 Android 单元测试运行,并使用 Assets 目录中的测试 HTML,我已经通过断言和调试确认了该目录的位置。我缺少什么?

** 更新 **我已经在调试中逐步完成了测试方法。它确实加载了 html(这是一个单元测试,所以我实际上看不到渲染的内容)。然后它会阻塞 wait() 调用,超时,然后在底部执行断言,而不会收到来自任一客户端的回调。 (Web 客户端和 Chrome 客户端都应该/会调用 notification())

这里的区别是我正在 Android 单元测试中运行。 WebView 不附加到任何 Activity 或容器。我想知道这是否与丢失的回调有关。我会尝试将其粘贴在 Activity 上,看看是否有任何区别。**/更新 **

public class MyWebViewTest extends InstrumentationTestCase {

private WebView webView;
private String html;

public void setUp() throws Exception {
super.setUp();
Context context = getInstrumentation().getContext();
this.webView = new WebView(context);
assertTrue("requires test.html",
Arrays.asList(context.getResources().getAssets().list("www")).contains("test.html"));
}

public void tearDown() throws Exception {

}

@JavascriptInterface
public void viewContent(String content) {
this.html = content;
}
public void testCanLoadAndReadWebContentFromWebView() throws Exception {
webView.addJavascriptInterface(this, "_webContainer");
webView.getSettings().setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView webView, String url) {
super.onPageFinished(webView, url);
onPageLoaded(webView);
}

@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
});

webView.setWebChromeClient(new WebChromeClient() {
@Override
public void onProgressChanged(WebView view, int newProgress) {
super.onProgressChanged(view, newProgress);
if(newProgress==100)
onPageLoaded(webView);
}
});

webView.loadUrl("file:///android_asset/www/test.html");
synchronized (this) {
wait(5000);
}
assertNotNull(html);
}


private void onPageLoaded(WebView webView) {
webView.loadUrl("javascript:window._webContainer.viewContent(document.documentElement.innerHTML);");
synchronized (this) {
notify();
}
}
}

最佳答案

我的猜测是正确的!当 WebView 未附加到 Activity 时,它不会加载、渲染或执行任何操作。我最终扩展了 ActivityInstrumentationTestCase2 并将 Web View 附加到 Activity。那时我的回调断点开始亮起。这是我的工作测试用例:

public class MyWebViewTest extends ActivityInstrumentationTestCase2<TestMeActivity> {

private WebView webView;
private String html;

public MyWebViewTest() {
super(TestMeActivity.class);
}

public void setUp() throws Exception {
super.setUp();
Context context = getInstrumentation().getContext();
this.webView = getActivity().getView();
assertTrue("requires test.html",
Arrays.asList(context.getResources().getAssets().list("www")).contains("test.html"));
}

public void tearDown() throws Exception {

}

@JavascriptInterface
public void viewContent(String content) {
this.html = content;
}

public void testCanLoadAndReadWebContentFromWebView() throws Exception {
getActivity().runOnUiThread(new Runnable() {
@Override
public void run() {
configureWebView();
}
});
synchronized (MyWebViewTest.this) {
MyWebViewTest.this.wait(25000);
}
assertEquals("<head></head><body>\n" +
"Hello\n" +
"\n" +
"</body>",html);
}

private void configureWebView() {
webView.addJavascriptInterface(this, "_webContainer");
WebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView webView, String url) {
super.onPageFinished(webView, url);
onPageLoaded(webView);
}
});

webView.loadUrl("file:///android_asset/www/test.html");
}


@TargetApi(Build.VERSION_CODES.KITKAT)
private void onPageLoaded(WebView webView) {
webView.evaluateJavascript("javascript:window._webContainer.viewContent(document.documentElement.innerHTML);",
new ValueCallback<String>() {
@Override
public void onReceiveValue(String value) {
synchronized (MyWebViewTest.this) {
MyWebViewTest.this.notify();
}
}
}
);
}
}

这是我为支持它而整理的 Activity :

public class TestMeActivity extends Activity{

private WebView view;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
view = new WebView(this);
setContentView(view);
}

public WebView getView() {
return view;
}
}

简而言之,从 Android TestCase 测试 WebView 的内容涉及相当多的工作。您必须向 Web View 添加一个 Javascript 接口(interface),插入一些 Javascript 来调用内部 Javascript 接口(interface)对象,通过该接口(interface)传递 Web View 的内容,最后将其收集到您的测试用例中。我当然希望它更容易,但这是我能想到的最好的。

关于javascript - WebViewClient onPageFinished 从未调用过,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32662442/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com