2017-07-29 14 views
0

android jellybeanでアンカータグのクリックイベントが機能しない4.2.2 webviewを使用しています。上記のバージョンではうまくいきます。Android webview javascript関数がアンカータグで機能しない

webView.getSettings().setJavaScriptEnabled(true); 
webView.loadUrl("javascript:(function(){document.getElementById('Accounts').click();})()"); 

これは私のアンカータグであり、これを変更することはできません。

<a href="Finacle;jsessionid=0000AT9YD5vrnOS9NJzIjdjJ4PD:1a33q40b7?bwayparam=j%2B2uf%2FBHaNA0ZGWt4ROCCTymgTzXQqv11%2Bfo1g9Jr8Zb1X2StMH26Jd%2FQ0EiE794ALKyEOjpbxhCm3IPgN61zCmWB5ZhKo2OiZRnAsRFLde2n56Kv4yz8ENMvTFzO6T8%0D%0AtXQFDgFsZMbGS28KN44DLVBb%2FQGDyNdvWhqaDSd5aqZEjDO0l1B%2F6x6RovcROwnJSFAG3awM%2FmbNHLvuSTcrwYeETC8B7UVmQBproSd7%2BC0%3D" 
id="Accounts" name="HREF_Accounts">Accounts</a> 

ガット・ソリューション: クリック()は、アンドロイドJSインターフェイスを使用して実装されていない場合、我々はこのように、HTML DOMイベントオブジェクトを使用する必要があります。

webView.loadUrl("javascript:(function(){"+ 
    "l=document.getElementById('Accounts');"+ 
    "e=document.createEvent('HTMLEvents');"+ 
    "e.initEvent('click',true,true);"+ 
    "l.dispatchEvent(e);"+ 
    "})()"); 

参考:https://stackoverflow.com/a/22866913/5370550

答えて

0

ここでの問題はEventBindingです。 webView.loadUrlで関数を呼び出すと、そのIDを持つ要素がdomにあり、バインドできません。この問題を回避するには、.on()機能を使用する必要があります。たとえば、

$('#Accounts').on('click',function(){ 
//... 
}); 

このメソッドでは、このIDを持つすべての要素がこのイベントにバインドされます。

+0

JavaScriptを使用してこれを変換するにはどうすればよいですか? – Nik

+0

このjqueryをjavascriptとして直接追加することができます。 WebView.loadUrl( "javascript:$( '#Accounts'))と同様に、(click、function(){ // ... })") –

+0

また、webviewでjavascriptを有効にすることを忘れないでください: WebView.getSettings()。setJavaScriptEnabled(true); –

関連する問題