Aka*_*shi 5 javascript android button webview
我有一个链接到我的商店网址的 WebView 应用程序,这里的问题是有一个按钮(添加到主屏幕)按钮,我想在我的 WebView 中隐藏该按钮类。我试图在 OnProgressChange 方法中使用 javascript 隐藏它它可以工作,但是,当我单击类别按钮并按主页按钮或再次返回主页时,再次出现“添加到主屏幕按钮”。有人可以帮助我或指导我如何完成这项任务。 这是商店链接
//WebView Settings and Configuration
Wview = (WebView) findViewById(R.id.webView);
WebSettings webSettings = Wview.getSettings();
webSettings.setJavaScriptEnabled(true);
Wview.setWebChromeClient(new chromeClient());
Wview.setWebViewClient(new myClient());
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
Wview.loadUrl(homeUrl);
}
private class myClient extends WebViewClient {
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
@Nullable
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
return super.shouldInterceptRequest(view, url);
}
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
boolean a = true;
if (url !=null && url.startsWith("whatsapp")){
view.getContext().startActivity(new Intent(Intent.ACTION_VIEW,Uri.parse(url)));
return true;
}
else if (url.startsWith("tel:")) {
Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse(url));
startActivity(intent);
}
else if (url.startsWith("rate:")) {
final String app_package = getPackageName(); //requesting app package name from Context or Activity object
try {
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + app_package)));
} catch (ActivityNotFoundException anfe) {
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=" + app_package)));
}
}
else if (url.startsWith("share:")) {
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setType("text/plain");
intent.putExtra(Intent.EXTRA_SUBJECT, view.getTitle());
intent.putExtra(Intent.EXTRA_TEXT, view.getTitle()+"\nVisit: "+(Uri.parse(url).toString()).replace("share:",""));
startActivity(Intent.createChooser(intent, getString(R.string.share_w_friends)));
}
else if (url.startsWith("exit:")) {
exitApp();
}// opening external URLs in android default web browser
else if (ext_url && !hostname(url).equals(homeUrl)) {
Wview(url,true, wError_counter);
// else return false for no special action
} else {
a = false;
}
return a;
}
@Override
public void onPageFinished(WebView view, String url) {
if(!errorOccured){
findViewById(R.id.welcome).setVisibility(View.GONE);
findViewById(R.id.webView).setVisibility(View.VISIBLE);
}
super.onPageFinished(view, url);
}
@Override
public void onReceivedHttpError(WebView view, WebResourceRequest request, WebResourceResponse errorResponse) {
super.onReceivedHttpError(view, request, errorResponse);
}
@Override
public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {
errorOccured=true;
findViewById(R.id.webView).setVisibility(View.GONE);
findViewById(R.id.welcome).setVisibility(View.VISIBLE);
//Intent intent = new Intent(getApplicationContext(), ErrorActivity.class);
// startActivity(intent);
}
}
//Random ID creation function to help get fresh cache every-time webview reloaded
public String random_id() {
return new BigInteger(130, random).toString(32);
}
//Opening URLs inside webview with request
void Wview(String url, Boolean tab, int error_counter) {
if(error_counter > 2){
wError_counter = 0;
exitApp();
}else {
if(tab){
if(cTAB) {
CustomTabsIntent.Builder intentBuilder = new CustomTabsIntent.Builder();
intentBuilder.setToolbarColor(ContextCompat.getColor(this, R.color.colorPrimary));
intentBuilder.setSecondaryToolbarColor(ContextCompat.getColor(this, R.color.colorPrimaryDark));
intentBuilder.setStartAnimations(this, android.R.anim.slide_in_left, android.R.anim.slide_out_right);
intentBuilder.setExitAnimations(this, android.R.anim.slide_in_left, android.R.anim.slide_out_right);
CustomTabsIntent customTabsIntent = intentBuilder.build();
try {
customTabsIntent.launchUrl(MainActivity.this, Uri.parse(url));
} catch (ActivityNotFoundException e) {
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(Uri.parse(url));
startActivity(intent);
}
}else{
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(Uri.parse(url));
startActivity(intent);
}
} else {
if (url.contains("?")) { // check to see whether the url already has query parameters and handle appropriately.
url += "&";
} else {
url += "?";
}
url += "rid=" + random_id();
Wview.loadUrl(url);
}
}
}
//Getting host name
public static String hostname(String url){
if (url == null || url.length() == 0) {
return "";
}
int dslash = url.indexOf("//");
if (dslash == -1) {
dslash = 0;
} else {
dslash += 2;
}
int end = url.indexOf('/', dslash);
end = end >= 0 ? end : url.length();
int port = url.indexOf(':', dslash);
end = (port > 0 && port < end) ? port : end;
Log.w("URL Host: ",url.substring(dslash, end));
return url.substring(dslash, end);
}
private void exitApp() {
Intent intent = new Intent(Intent.ACTION_MAIN);
intent.addCategory(Intent.CATEGORY_HOME);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intent);
}
// Creating exit dialogue
public void ask_exit(){
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
builder.setTitle(getString(R.string.exit_title));
builder.setMessage(getString(R.string.exit_subtitle));
builder.setCancelable(true);
// Action if user selects 'yes'
builder.setPositiveButton("Yes", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
finish();
}
});
// Actions if user selects 'no'
builder.setNegativeButton("No", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
});
// Create the alert dialog using alert dialog builder
AlertDialog dialog = builder.create();
// display the dialog when user press back button
dialog.show();
}
@Override
public void onBackPressed() {
if (Wview.canGoBack()) {
Wview.goBack();
} else if (ask_ExitDial) {
ask_exit();
} else {
super.onBackPressed();
this.finish();
}
}
private class chromeClient extends WebChromeClient {
@Override
public void onProgressChanged(WebView view, int newProgress) {
Wview.loadUrl("javascript:(function() { " +
"document.getElementsByClassName('sc-iQKALj cdqULD border border-gray-dae')[0].style.display='none'; " +
"})()");
super.onProgressChanged(view, newProgress);
}
}
private class touchlistener implements View.OnTouchListener {
@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
WebView.HitTestResult hitTestResult=((WebView)view).getHitTestResult();
hitResult=true;
return false;
}
}
}
Run Code Online (Sandbox Code Playgroud)
所以基本上问题是检测 WebView 内部的变化并以特定的方式对它们做出反应。
内部的更改WebView可以有多种类型 - 实际的重新加载和 Dom 更改 - 是我们应该听取的主要内容。WebViewClient.shouldInterceptRequest虽然侦听重新加载相对容易,并且可以在回调中完成WebViewClient.shouldOverrideUrlLoading,但无法通过 Android WebViewAPI 跟踪 DOM 更改。
private class myClient extends WebViewClient {
...
@Nullable
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
Wview.evaluateJavascript("javascript:(function() { " +
"document.getElementsByClassName('sc-iQKALj cdqULD border border-gray-dae')[0].style.display='none'; " +
"})()");
return super.shouldInterceptRequest(view, url);
}
...
}
Run Code Online (Sandbox Code Playgroud)
为了跟踪 DOM 中的更改,我们可以使用 JavaScript,特别是MutationObserver- 您必须通过WebViewjs 注入功能将已实现的回调注入代码。为此,如果您的最低 API 级别高于 19,请尝试使用webView.evaluateJavascript而不是webView.loadUrl.
您也可以使用Activity.onBackPressed方法和WebView.setOnKeyListener连词。它看起来像这样:
public void onBackPressed() {
if (Wview.canGoBack()) {
Wview.goBack();
Wview.evaluateJavascript("javascript:(function() { " +
"document.getElementsByClassName('sc-iQKALj cdqULD border border-gray-dae')[0].style.display='none'; " +
"})()");
} else if (ask_ExitDial) {
ask_exit();
} else {
super.onBackPressed();
this.finish();
}
}
Wview.setOnKeyListener((View.OnKeyListener) (v, keyCode, event) -> {
if (event.getAction() != KeyEvent.ACTION_DOWN)
return true;
if (keyCode == KeyEvent.KEYCODE_BACK) {
if (Wview.canGoBack()) {
Wview.goBack();
Wview.evaluateJavascript("javascript:(function() { " +
"document.getElementsByClassName('sc-iQKALj cdqULD border border-gray-dae')[0].style.display='none'; " +
"})()");
} else {
((Activity) this).onBackPressed();
}
return true;
}
return false;
});
Run Code Online (Sandbox Code Playgroud)
它可能有效也可能无效,具体取决于您的网站架构。
因此,你唯一的选择就是尝试并希望它能奏效。一般来说,在 Android 上使用 webview 是相当痛苦的,所以......是的。
希望它能以某种方式帮助你。
| 归档时间: |
|
| 查看次数: |
302 次 |
| 最近记录: |