のテキスト フィールドを事前に入力する必要があり、これが最善の方法でUIWebView
あることがわかります。javascript
残念ながら、私は何も知らずjavascript
、ここ数時間手探りで、どこにも行き着きませんでした.
最近の失敗した試み:
- (void)webViewDidFinishLoad:(UIWebView *)webView
{
// username field id = username_5 & pw field id = password_5
NSString *javascript = @"\
var user = 'testUser';\
var pw = 'testPW';\
document.getElementById('username_5').value = user; \
document.getElementById('password_5').value = pw; \
;";
// Execute JS
[_emailWebView stringByEvaluatingJavaScriptFromString:javascript];
}
誰かが私を正しい方向に向けることができますか?
-編集-
また、ページが完全に読み込まれていない場合に備えて、呼び出しを遅らせてみました。次のような呼び出しを行った場合:
- (void)webViewDidFinishLoad:(UIWebView *)wv
{
[NSObject cancelPreviousPerformRequestsWithTarget:self];
[self performSelector:@selector(injectJavascript) withObject:nil afterDelay:1.0];
}
- (void)injectJavascript
{
[self.emailWebView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"document.getElementById('password_5').value = 'testPW';"]];
[self.emailWebView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"window.alert('test');"]];
}
アラートは表示されますが、ID のフィールドpassword_5
は入力されていません。
問題のフィールドはフォーム内にネストされています。それが違いを生むかどうかわかりませんか?
-編集2-
別のサイトでこれを試してみたところ、問題がターゲット Web サイトの HTML/ネストに関連していると確信しています。
ターゲット サイトは次のようにネストされます。
<html>
<head> … </head>
<body onload="FinishLoad(1);hideJSWarn();">
<div id="noJSWarn" class="cssSecurityWarning" style="display: none;"> … </div>
<table id="table_LoginPage_1" > … </table>
<table id="table_LoginPage_2" > … </table>
<blockquote>
<form id="frmLogin_4" onsubmit="return Login(1)" autocomplete="off" method="POST" action="login.cgi" name="frmLogin">
<input id="tz_offset_5" type="hidden" name="tz_offset"></input>
<table id="table_LoginPage_3" >
<tbody>
<tr> …
<td valign="top">
<table id="table_LoginPage_6" >
<tbody>
<tr>
<td> … </td>
<td>
<input id="username_5" type="text" size="20" name="username"></input>