<input type="text" name="startDate" class="release-body-group-content-input datepicker ng-isolate-scope ng-pristine ng-valid ng-valid-date" datepicker-popup="yyyy-MM-dd" ng-model="dt.date" is-open="dt.opened" max-date="maxDate" min-date="minDate" datepicker-options="dateOptions" current-text="今天" clear-text="取消" close-text="关闭" ng-click="openDatepicker()" tabindex="-1" readonly="">
一、由于是日期格式,无法sendkey
方案一(亲测:成功):使用JS remove readonly attribute,然后sendKeys
注意:getElementsByName是数组 需要去数组哪一个 :getElementsByName('startDate')[0]
getElementById非数组,可直接使用
date_src = "var setDate=document.getElementsByName('startDate')[0];setDate.removeAttribute('readonly');" date_loc = (By.XPATH, '/html/body/div[1]/div/div[3]/div/table/tbody/tr/td[2]/div/form/div[2]/div[9]/div[2]/div/input') # 日期 def date(self,date): self.script(self.date_src) self.find_element(*self.date_loc).send_keys(date)方案二:采用click直接选择日期,日期控件是一个iframe,首先switch iframe,之后找到想要设置的日期button click,然后switch出来
WebElement dayElement=driver.findElement(By.xpath("//span[@id='from_imageClick']")); dayElement.click(); // WebElement frameElement=driver.findElement(By.xpath("//iframe[@border='0']")); driver.switchTo().frame(1); driver.findElement(By.xpath("//tr/td[@onclick='day_Click(2015,2,21);']")).click(); driver.switchTo().defaultContent();