Android Native 与 HTML 交互
在Android中,你可以使用WebView组件来展示HTML内容,并通过JavaScript接口与WebView中的HTML页面进行交互。以下是一个简单的例子,展示了如何从Android原生代码中调用HTML页面中的JavaScript函数。
首先,在你的布局文件中添加WebView:
<WebView
android:id="@+id/webview"
android:layout_width="match_parent"
android:layout_height="match_parent" />
然后,在你的Activity中设置WebView并加载你的HTML页面:
public class MainActivity extends AppCompatActivity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = findViewById(R.id.webview);
// 启用JavaScript
WebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);
// 设置WebViewClient用于加载页面
webView.setWebViewClient(new WebViewClient());
// 加载你的HTML页面
webView.loadUrl("file:///android_asset/your_html_page.html");
// 添加JavaScript接口用于与JavaScript交互
webView.addJavascriptInterface(new WebAppInterface(this), "Android");
}
// 自定义的接口类
public class WebAppInterface {
Context mContext;
WebAppInterface(Context c) {
mContext = c;
}
// 显示Toast的JavaScript接口函数
@JavascriptInterface
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
}
}
}
在HTML页面中,你可以这样调用Android原生函数:
<!DOCTYPE html>
<html>
<head>
<title>Sample Page</title>
<script type="text/javascript">
function showAndroidToast(toast) {
Android.showToast(toast);
}
</script>
</head>
<body>
<button onclick="showAndroidToast('Hello from Web!')">
Show Toast from Web
</button>
</body>
</html>
当用户点击按钮时,它将调用Android.showToast()
函数,并将来自HTML页面的消息传递给Android应用。这就实现了HTML与Android Native间的交互。
评论已关闭