Решение:
Использование document.getElementsByClassName()
.
Пример:
HTML-часть (button_tchromium.html).Я определил класс для целей тестирования.
<html>
<head>
<meta http-equiv="X-UA-Compatible" content="IE=edge"/>
<style>
._2lkdt {
border: 1px solid black;
margin: 25px;
}
</style>
</head>
<body>
<button onclick="alert('I am clicked');" class="_2lkdt">
<span data-icon="send" class="">
<svg id="Layer_1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
<path fill="#263238" fill-opacity=".45" d="M1.101 21.757L23.8 12.028 1.101 2.3l.011 7.912 13.623 1.816-13.623 1.817-.011 7.912z"></path>
</svg>
</span>
</body>
</html>
DELPHI part:
Только для этого теста я использую две кнопки в форме, одну для загрузки html-файла и другую для выполненияJavaScript.Просто проверьте поддержку браузера getElementsByClassName()
.
procedure TForm1.btnExecuteClick(Sender: TObject);
var
code: string;
frame: ICefFrame;
begin
code := 'var items = document.getElementsByClassName("_2lkdt"); '+
'for (var i = 0; i < items.length; i++) { ' +
'if (items[i].nodeName.toLowerCase() === "button") {' +
'items[i].click(); ' +
'}' +
'}';
frame := Chromium1.Browser.MainFrame;
frame.ExecuteJavaScript(code, frame.Url, 0);
end;
Примечания:
Протестировано с Delphi7 и TChromium (Delphi Chromium Embeded, ветвь dcef3-2378).