Android WebView详解和调用JS,android开发游戏加入时间限制

本文详述了Android中WebView的使用,包括创建自定义WebViewClient以控制网页加载行为,启用JavaScript支持,以及处理缓存策略。同时,介绍了如何在WebView中调用JS函数,展示了相关代码实例,是Android开发者的重要参考资料。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(3)创建一个自己的WebViewClient,通过setWebViewClient关联

//覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开

mWebView.setWebViewClient(new WebViewClient() {

@Override

public boolean shouldOverrideUrlLoading(WebView view, String url) {

//返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器

view.loadUrl(url);

return true;

}

/**

  • 1.网页页面开始加载的时候,执行的回调方法,可以实现加载等待界面

  • 2.在此方法中设置一个超时计时器

  • @param view

  • @param url

  • @param favicon

*/

@Override

public void onPageStarted(WebView view, String url, Bitmap favicon) {

super.onPageStarted(view, url, favicon);

mLinearLayout.setVisibility(View.GONE);

mRelativeLayout.setVisibility(View.VISIBLE);

}

/**

  • 1.网页加载结束的时候,也要隐藏等待界面

  • 2.onPageFinished指页面加载完成,完成后取消计时器

  • @param view

  • @param url

*/

@Override

public void onPageFinished(WebView view, String url) {

super.onPageFinished(view, url);

mLinearLayout.setVisibility(View.VISIBLE);

mRelativeLayout.setVisibility(View.GONE);

}

/**

  • 加载异常的界面

  • @param view

  • @param request

  • @param error

*/

@Override

public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {

super.onReceivedError(view, request, error);

Log.d(“testTimeout”, “-----------加载异常”);

}

});

(4)访问的页面中有Javascript,则webview必须设置支持Javascript

We

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

bSettings mWebSettings = mWebView.getSettings();

mWebSettings.setJavaScriptEnabled(true);

(5)缓存的使用

优先使用缓存

mWebView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);

不使用缓存

mWebView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);

特殊使用

先给大家说说怎么获取这个html的标题title

应用开发的时候使用WebView这个组件的过程中可能会接触到WebViewClient与WebChromeClient,那么这两个类到底有什么不同呢 ,WebViewClient主要帮助WebView处理各种通知、请求事件的,比如:

onLoadResource

onPageStart

onPageFinish

onReceiveError

onReceivedHttpAuthRequest

WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等比如

onCloseWindow(关闭WebView)

onCreateWindow()

onJsAlert (WebView上alert无效,需要定制WebChromeClient处理弹出)

onJsPrompt

onJsConfirm

onProgressChanged

onReceivedIcon

onReceivedTitle

我们在 WebChromeClient 中的 onReceivedTitle() 方法里判断html页面的标题中是否含有 “error”,如果有,则证明html加载失败,设置加载失败的标记,让在 WebViewClient 的完成是回 调的 onPageFinish() 方法里显示自定义的加载失败的页面。

使用的是不要忘了添加网络权限:

最后张贴一下全部代码:

public class MainActivity extends AppCompatActivity {

private WebView mWebView;

private ProgressBar mProgressBar;

private LinearLayout mLinearLayout;

private RelativeLayout mRelativeLayout;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);

setSupportActionBar(toolbar);

init();

}

private void init() {

mWebView = (WebView)findViewById(R.id.webview);

mProgressBar = (ProgressBar)findViewById(R.id.progressBar);

mLinearLayout = (LinearLayout)findViewById(R.id.linearlayout);

mRelativeLayout = (RelativeLayout)findViewById(R.id.relativwlayout);

//WebView加载web资源

mWebView.loadUrl(“https://www.baidu.com/”);

/**

  • 对WebView设置监听器

*/

WebSettings mWebSettings = mWebView.getSettings();

mWebSettings.setJavaScriptEnabled(true);

mWebView.setWebChromeClient(new WebChromeClient() {

@Override

public void onProgressChanged(WebView view, int newProgress) {

super.onProgressChanged(view, newProgress);

if (newProgress == 100) {

mProgressBar.setVisibility(View.GONE);

} else {

mProgressBar.setVisibility(View.VISIBLE);

mProgressBar.setProgress(newProgress);

}

}

});

//覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开

mWebView.setWebViewClient(new WebViewClient() {

@Override

public boolean shouldOverrideUrlLoading(WebView view, String url) {

//返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器

view.loadUrl(url);

return true;

}

/**

  • 1.网页页面开始加载的时候,执行的回调方法,可以实现加载等待界面

  • 2.在此方法中设置一个超时计时器

  • @param view

  • @param url

  • @param favicon

*/

@Override

public void onPageStarted(WebView view, String url, Bitmap favicon) {

super.onPageStarted(view, url, favicon);

mLinearLayout.setVisibility(View.GONE);

mRelativeLayout.setVisibility(View.VISIBLE);

}

/**

  • 1.网页加载结束的时候,也要隐藏等待界面

  • 2.onPageFinished指页面加载完成,完成后取消计时器

  • @param view

  • @param url

*/

@Override

public void onPageFinished(WebView view, String url) {

super.onPageFinished(view, url);

mLinearLayout.setVisibility(View.VISIBLE);

mRelativeLayout.setVisibility(View.GONE);

}

/**

  • 加载异常的界面

  • @param view

  • @param request

  • @param error

*/

@Override

public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {

super.onReceivedError(view, request, error);

Log.d(“testTimeout”, “-----------加载异常”);

}

});

//设置访问文件

mWebSettings.setAllowContentAccess(true);

mWebSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);

}

/**

  • 在onKeyDown中设置webView在返回的时候

  • 自动记录浏览记录

  • @param keyCode

  • @param event

  • @return

*/

@Override

public boolean onKeyDown(int keyCode, KeyEvent event) {

if (keyCode == KeyEvent.KEYCODE_BACK){

if (mWebView.canGoBack()){

mWebView.goBack();

return true;

}else {

finish();

}

}

return super.onKeyDown(keyCode, event);

}

}

WebView调用JS的使用方式

(1)首先写js文件 js_test.js

function alertFromJs(content){

alert(“From js:” + content);

}

简单的一个函数,功能就是弹出一个alert。

写html文件 index.html,在html里加载js文件,注意路径

JS Test

加载HTML网页成功!

将index.html和js_test.js放到JsTest文件夹里,将JsTest放入到安卓工程assets中。

写xml布局文件:

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:tools=“http://schemas.android.com/tools”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

tools:context=".MainActivity">

<Button

android:id="@+id/btnCallJSAlert"

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:gravity=“center”

android:text=“CALL JS ALERT” />

<WebView

android:id="@+id/wvTest"

android:layout_width=“match_parent”

android:layout_height=“match_parent” />

MainActivity的所有代码:

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

private WebView wvTest;

private Button btnCallJSAlert;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

wvTest = (WebView) findViewById(R.id.wvTest);

btnCallJSAlert = (Button) findViewById(R.id.btnCallJSAlert);

btnCallJSAlert.setOnClickListener(this);

//处理Javascript的对话框,加载进度等。我们是一个用js弹出对话框的程序,所以这句必须加。

wvTest.setWebChromeClient(new WebChromeClient());

//拿到WebSettings

WebSettings webSettings = wvTest.getSettings();

//设置编码格式

webSettings.setDefaultTextEncodingName(“utf-8”);

//支持js

webSettings.setJavaScriptEnabled(true);

wvTest.loadUrl(“file:///android_asset/JsTest/index.html”);

}

@Override

public void onClick(View view) {

switch (view.getId()) {

case R.id.btnCallJSAlert:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

wvTest.evaluateJavascript(“javascript:alertFromJs(‘加载网页的wvTest.evaluateJavascript’)”, new ValueCallback() {

/**

  • 网页上的Button回调方法

  • @param value

*/

@Override

public void onReceiveValue(String value) {

Log.i(“TAG”,"网页上的Button回调方法:value = "+value);

}

});

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值