我正在尝试选中该复选框,但出现以下错误
selenium.common.exceptions.NoSuchElementException: Message: no such
element: Unable to locate element: {"method":"xpath","selector":"//mat-
checkbox[@id='mat-checkbox-1']/label/div"}
我尝试使用id,css-selector和xpath进行选择,但一直出错。
reg_date_checkbox = self.browser.find_element_by_xpath("//matcheckbox[@id='mat-checkbox-1']/label/div")
reg_date_checkbox.location_once_scrolled_into_view
reg_date_checkbox.click()
复选框的HTML是
<div _ngcontent-fep-c23="" class="last-date my-12 ng-star-inserted" fxlayout="column" style="flex-direction: column; box-sizing: border-box; display: flex;">
<mat-checkbox _ngcontent-fep-c23="" class="mat-checkbox mat-accent ng-untouched ng-pristine ng-valid" formcontrolname="deadline_enabled" id="mat-checkbox-1">
<label class="mat-checkbox-layout" for="mat-checkbox-1-input">
<div class="mat-checkbox-inner-container">
<input class="mat-checkbox-input cdk-visually-hidden" type="checkbox" id="mat-checkbox-1-input" tabindex="0" aria-checked="false">
<div class="mat-checkbox-ripple mat-ripple" matripple="">
<div class="mat-ripple-element mat-checkbox-persistent-ripple"></div>
</div>
<div class="mat-checkbox-frame"></div>
<div class="mat-checkbox-background">
<svg xml:space="preserve" class="mat-checkbox-checkmark" focusable="false" version="1.1" viewBox="0 0 24 24">
<path class="mat-checkbox-checkmark-path" d="M4.1,12.7 9,17.6 20.3,6.3" fill="none" stroke="white"></path>
</svg>
<div class="mat-checkbox-mixedmark"></div>
</div>
</div><span class="mat-checkbox-label"><span style="display:none"> </span>The event has a registration deadline</span>
</label>
</mat-checkbox>
<!---->
答案 0 :(得分:0)
您正在使用此xpath //matcheckbox[@id='mat-checkbox-1']/label/div
,应该是//mat-checkbox[@id='mat-checkbox-1']/label/div
,中间有一个-
,您会丢失它。
仍然可以使用此 css选择器:
div.mat-checkbox-inner-container input[class^='mat-checkbox-input'][id^='mat-checkbox']
复选框可能存在于iframe中,如果是这种情况,请先切换到框架,然后尝试单击复选框。
答案 1 :(得分:0)
您可以尝试以下方法:
element = self.browser.find_element_by_css("input#mat-checkbox-1-input")
element.click()
答案 2 :(得分:0)
您可能正在尝试单击非“复选框”类型的元素。我看到有一个带有类型复选框的输入。请尝试下面提到的代码
reg_date_checkbox = self.browser.find_element_by_xpath("//input[@id='mat-checkbox-1-input']")
reg_date_checkbox.click()
另外,如果您希望执行取消选中操作,则可以在执行单击之前查找输入元素的aria-checked属性为true。