Enabling general JavaScript in WebViewClient

AndroidWebviewWebviewclient

Android Problem Overview


While searching for an answer in google, it seems that I'm not the only one stuck with a problem that seems impossible to solve.

I've managed to create a WebView with a custom WebViewClient - this makes it possible for me to have a processdialog and show an error message if an URL couldn't be loaded.

But this creates a problem with JavaScript. The URL I'm loading has some JavaScript which changes some HTML elements CSS styles (showing or hiding element) or redirects to another location onclick - or maybe even want's to show an alert box. But by using the WebViewClient none of those are working.

This is how I load a page:

public void loadUrl(String url)
{
	final ProgressDialog dialog = ProgressDialog.show(myActivity.this, "",  getString(R.string.loading), true);
			final WebView myWebView = (WebView) findViewById(R.id.webview);
			myWebView.setVerticalScrollBarEnabled(false);
			myWebView.setHorizontalScrollBarEnabled(false);
			WebSettings webSettings = myWebView.getSettings();
			webSettings.setJavaScriptEnabled(true);											
			
				
			myWebView.setWebViewClient(new WebViewClient() 
			{
				@Override
				public boolean shouldOverrideUrlLoading(WebView view, String url) 
				{
					Toast.makeText(myActivity.this, url, Toast.LENGTH_SHORT).show(); //Debugging purposes
			    if (url.endsWith(".mp4")) 
			    {
						Intent intent = new Intent(Intent.ACTION_VIEW);
						intent.setDataAndType(Uri.parse(url), "video/mp4");
						view.getContext().startActivity(intent);  
			    }
			    else
			    {	    			    	
						view.loadUrl(url);
					}

					return true;
				}
				
				public void onPageFinished(WebView view, String url) 
				{
					//Toast.makeText(myActivity.this, "Oh no!", Toast.LENGTH_SHORT).show();
					dialog.dismiss();
				}

				public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) 
				{
					Toast.makeText(myActivity.this, description, Toast.LENGTH_SHORT).show();
					String summary = "<html><body><strong>" + getString(R.string.lost_connection) + "</body></html>";
					myWebView.loadData(summary, "text/html", "utf-8");   
				}			   
			 
			 }); //End WebViewClient
						
			myWebView.loadUrl(url);		
		}

This could probably be done in a smarter way, but I'm new at both Java and Android development...

Is it possible for me to enable the JavaScript for the WebViewClient at all? Removing the WebViewClient solves the problem, but then I can't catch events when the page errors or is finished loading.

Android Solutions


Solution 1 - Android

I don't know what your exact problem is, but i can enable the JavaScript and a custom WebViewclient without any problem:

WebView vistaWeb = (WebView) findViewById(R.id.webview);
vistaWeb.setWebChromeClient(new MyCustomChromeClient(this));
vistaWeb.setWebViewClient(new MyCustomWebViewClient(this));
vistaWeb.clearCache(true);
vistaWeb.clearHistory();
vistaWeb.getSettings().setJavaScriptEnabled(true);
vistaWeb.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);

Solution 2 - Android

The proper way to enable JavaScript is by add the below two lines:

mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);

Even if after adding its not working then try adding the below line.

mWebView.getSettings().setDomStorageEnabled(true);

Now It should work. :)

Solution 3 - Android

Try this to enable javascript

WebView myWebView = (WebView) findViewById(R.id.webView);
myWebView.getSettings().setJavaScriptEnabled(true);
myWebView.setWebViewClient(new WebViewClient());
myWebView.loadUrl(url);

Solution 4 - Android

What happened in my case : I was serving local html files and when applying

    web.getSettings().setJavaScriptEnabled(true);
    web.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);

but then my urls stopped working. Solution to make both JS and local href work was to add

    web.getSettings().setAllowFileAccess(true);
    web.getSettings().setAllowFileAccessFromFileURLs(true);

where

    web = (WebView) findViewById(R.id.embedded_web);

Solution 5 - Android

-> Hello Please Try This Code This Code Run Fine

-> For More Information of Documentation Please Visit https://developer.android.com/guide/webapps/webview#java

-> This Link Work Fine in Nov 2019 Currently I Don't Know

-> Your XML Code For Design is

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <WebView
        android:id="@+id/webview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        />


</LinearLayout>

-> And Your Java Code For Backend is

package com.developer.harshil.kaneria.webview;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        WebView myWebView = (WebView) findViewById(R.id.webview);
        WebSettings webSettings = myWebView.getSettings();
        webSettings.setJavaScriptEnabled(true);

        myWebView.loadUrl("https://github.com/Harshil-Kaneria");
    }
}

-> Here in Java Code

> WebSettings webSettings = myWebView.getSettings();

And This

> webSettings.setJavaScriptEnabled(true);

-> It is Allow To JavaScript Run When Page is Load

-> Thanks A Lot For Read.

Solution 6 - Android

Do "Javascript-URLs" get routed through shouldOverrideUrlLoading? Try checking that and if so, return false for links like that (so that the webview handles the link, not your WebViewClient)

Solution 7 - Android

Similar to @mdelolmo answer, but in Kotlin:

    webview.setWebChromeClient(WebChromeClient())
    webview.setWebViewClient(WebViewClient())
    webview.clearCache(true)
    webview.clearHistory()
    webview.getSettings().setJavaScriptEnabled(true)
    webview.getSettings().setJavaScriptCanOpenWindowsAutomatically(true)

Solution 8 - Android

How enable programmatically answered in other answers. But some javascripts not worked if your webview is in nestedscrollview. Remove it and add webSettings.setJavaScriptEnabled(true);

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionRepoxView Question on Stackoverflow
Solution 1 - AndroidmdelolmoView Answer on Stackoverflow
Solution 2 - AndroidTatson BaptistaView Answer on Stackoverflow
Solution 3 - AndroidRishabh GuptaView Answer on Stackoverflow
Solution 4 - AndroidNejc MedvedView Answer on Stackoverflow
Solution 5 - AndroidHarshil KaneriaView Answer on Stackoverflow
Solution 6 - AndroidTimo OhrView Answer on Stackoverflow
Solution 7 - AndroidJerry ChongView Answer on Stackoverflow
Solution 8 - AndroiddimvolkView Answer on Stackoverflow