嗨,我有一个基于 ExtJS 的用户界面。我知道在 ExtJS 中,组合框不是真正的组合框,而是输入文本字段、下拉框图像和列表的组合。现在我能够识别控件,但我坚持从列表中选择值。在 HTML 源代码中,我看到该列表显示为单独的 div,并在我们单击下拉列表时附加在源代码的末尾。在下拉控件的 HTML 源代码下方找到。{
<div id="ext-gen678" class="x-form-field-wrap x-form-btn-plugin-wrap" style="width: 556px;">
<div id="ext-gen676" class="x-form-field-wrap x-form-field-trigger-wrap x-trigger-wrap-focus" style="width: 521px;">
<input id="ext-gen677" type="hidden" name="GHVOg:#concat#~inputFld~ISGP_UNIV:ft_t_isgp.prnt_iss_grp_oid:0" value="">
<input id="GHVOg:Mixh8:0" class="x-form-text x-form-field gs_dropDown_input gs_req x-form-invalid x-form-focus" type="text" autocomplete="off" size="24" style="width: 504px;">
<img id="trigger-GHVOg:Mixh8:0" class="x-form-trigger x-form-arrow-trigger" alt="" src="../../ext/resources/images/default/s.gif">
}
在下拉列表的 HTML 源代码下方找到:
<div id="ext-gen726" class="x-layer x-combo-list x-resizable-pinned" style="position: absolute; z-index: 12007; visibility: visible; left: 294px; top: 370px; width: 554px; height: 123px; font-size: 11px;">
<div id="ext-gen727" class="x-combo-list-inner" style="width: 554px; margin-bottom: 8px; height: 114px;">
<div class="x-combo-list-item"></div>
<div class="x-combo-list-item">12h Universe</div>
<div class="x-combo-list-item">1h Universe</div>
<div class="x-combo-list-item">24h Universe</div>
<div class="x-combo-list-item">2h Universe</div>
<div class="x-combo-list-item x-combo-selected">4h Universe</div>
现在我从列表中选择值时遇到问题,因为列表的 div 元素未附加到控件。另请参阅屏幕截图,其中我有多个类似的控件 [命名为“向宇宙添加安全性”]
在屏幕截图中,您可以看到突出显示的多个下拉列表 [向 Universe 添加安全性],并且所有下拉列表中的值都相同。那么我如何从下拉列表中识别这些值。我想知道 ExtJS 如何维护下拉 div 元素与组合框小部件的映射,以便我可以使用相同的逻辑来识别列表。谁能告诉我如何在 selenium webdriver 中做这件事?