篇介紹了表單的使用,表單有很多控件,比如輸入框,密碼框、文本域,按鈕等。按類型可分如下:
此類控件有很多種類型,使用<input type="類型">語法,常見類型如下:
type 值 | 含義 |
text | 文字字段 |
password | 密碼域,用戶看不到明文,以*代替 |
radio | 單選按鈕 |
checkbox | 多選按鈕 |
button | 普通按鈕 |
submit | 提交按鈕 |
reset | 重置按鈕 |
image | 圖像域,用圖像作為背景的提交按鈕 |
hidden | 隱藏域,不可見的輸入框 |
file | 文本域,用于上傳文件等非文本數據 |
文本輸入框和密碼框
除了顯示形式不一樣,其它屬性一樣,有以下屬性:
如下是文本輸入框和密碼框制作一個登錄表單
html代碼:
<!DOCTYPE html>
<html>
<body>
<h1>用戶登錄</h1>
<form action="/demo/html/action_page.php">
<label for="fname">用戶名:</label><br>
<input type="text" id="username" name="username" value=""><br>
<label for="lname">密碼:</label><br>
<input type="password" id="pwsd" name="pwsd" value=""><br><br>
<input type="submit" value="提交">
</form>
</body>
</html>
顯示效果:
HTML5 輸入類型
除了以上幾種類型,HTML5 還增加了多個新的輸入類型:
如下代碼:
<!DOCTYPE html>
<html>
<body>
<form action="/demo/demo_form.asp">
數字類型(1 到 5 之間):
<input type="number" name="quantity" min="1" max="5">
IE9 及早期版本不支持 type="number"。<br>
color 選擇顏色:
<input type="color" name="color"><br>
生日:
<input type="date" name="bday"><br>
年月:
<input type="month" name="bdaymonth"><br>
年周:
<input type="week" name="week_year"><br>
時間:
<input type="time" name="usr_time"><br>
一定范圍
<input type="range" name="points" min="0" max="10"><br>
E-mail:
<input type="email" name="email">
能夠在被提交時自動對電子郵件地址進行驗證<br>
搜索:
<input type="search" name="googlesearch"><br>
電話:
<input type="tel" name="usrtel">
目前只有 Safari 8 支持 tel 類型。<br>
url:
<input type="url" name="url">
提交時能夠自動驗證 url 字段<br>
<input type="submit">
</form>
</body>
</html>
效果如下:
單選和多選按鈕
使用 type = “radio” 和 type =“checkbox” 定義是單選還是多選,除了name和value屬性外,單選和多選都有一個 checked屬性定義默認選擇的項,checked = “true”指選中那個選項,表單會將 checked = “true” 的選型值傳遞給后臺。
如下實例:
<!DOCTYPE html>
<html>
<body>
<h4>單選和多選</h4>
<form action="/demo/demo_form.asp">
水果:
<input type="radio" name="shuiguo" value="banner" checked> 香蕉
<input type="radio" name="shuiguo" value="apple"> 蘋果
<br><br>
省份:
<input type="checkbox" name="shengfen" value="shannxi" checked> 陜西
<input type="checkbox" name="shengfen" value="sanxi"> 山西
<input type="checkbox" name="shengfen" value="gdong"> 廣東
<br><br>
<input type="submit">
</form>
</body>
</html>
顯示效果:
單選和多選傳遞給后臺的數據是不一樣的,如下會看到地址欄中的數據,多選會發送多個值,后臺將會獲取一個數組形式的數據。
/demo/demo_form.asp?shuiguo=banner&shengfen=shannxi&shengfen=sanxi
普通按鈕、提交按鈕、重置按鈕
普通按鈕:type = “button”,一般配合腳本使用,語法如下:
<input type="button" name="名稱" value="按鈕值" onclick="腳本程序" />
value 值就是按鈕在頁面顯示的文字,onclick屬性定義了腳本事件,這里指單擊按鈕時所進行的處理。
如下示例:
<!DOCTYPE html>
<html>
<body>
<form>
<input type="button" value="普通按鈕">
<input type="button" value="打開窗口" onclick="window.open()">
<input type="button" value="您好" onclick="alert('您好')">
</form>
</body>
</html>
單擊您好按鈕
提交按鈕:type = “submit”,用于提交表單內容,是一種特殊按鈕。
如剛才的登錄表單,提交后會返回結果:
重置按鈕:type="reset",用于清除表單數據,也是一種特殊按鈕。
輸入數據
點擊重置按鈕后,表單數據清空
重置清空數據
HTML5 按鈕
除了使用input定義按鈕,還可以使用 html5 新增的<button> 標簽定義按鈕,button 使用語法如下:
<form action="/demo/html/action_page.php">
<button type="button">普通按鈕</button>
<button type="submit">提交按鈕</button>
</form>
其它輸入類控件
隱藏域 —— hidden
文件域 —— file
如下示例:
<form action="/demo/html/action_page.php">
<label for="fname">隱藏域:</label>
<input type="hidden" id="hidden" name="hidden" value=""><br>
<label for="lname">文件域:</label>
<input type="file" id="file" name="file" value=""><br>
<input type="submit" value="提交">
</form>
顯示效果
可以看到,隱藏域在頁面中不顯示,單擊文件域選擇文件按鈕可以選擇文件,比如word文件,電子表格文件等,會以非文本方式傳送到后臺的,常用來實現文件上傳功能。
除了input 類型的控件,還有文本域 textarea ,一種特殊的文本框,它與input 文本輸入框的區別就是可以輸入多行文字,input 文本輸入框是單行的無法輸入多行文字。
如下示例:
<p>textarea 元素定義多行輸入字段。</p>
<form action="/demo/html/action_page.php">
<textarea name="message" rows="10" cols="30">The cat was playing in the garden.</textarea>
<br><br>
<input type="submit">
</form>
效果如下:
rows 屬性定義文本域的高度是幾行,cols 定義文本域寬度占幾列,比如上面定義了高10行寬30列的文本域。
下拉菜單作用和單選按鈕類似,只不過它更加節省空間,當要選擇的選型很多時,就不適合使用radio空間,所以當選項很多的時候,使用下拉菜單,語法如下:
<select name="名稱">
<option value="選項值1" selected>選項1</option>
<option value="選項值2">選項3</option>
更多option......
</select>
多選列表和多選按鈕類似,一樣為了節省空間,當數據選項比較多時,使用多選列表,語法如下:
<select name="名稱" size="可看見的列表項數" multiple>
<option value="選項值1" selected>選項1</option>
<option value="選項值2">選項3</option>
更多option......
</select>
多選比下拉菜單不同之處是多了一個multiple屬性,定義多選的,且表現形式也不一樣,不是下拉而是一個列表。
如下代碼:
<!DOCTYPE html>
<html>
<body>
<form action="/demo/demo_form.asp">
下拉菜單:<br>
<select name="cars">
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
<option value="fiat">Fiat</option>
<option value="audi">Audi</option>
</select>
<br>
多選列表:<br>
<select name="cars" size="3" multiple>
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
<option value="fiat">Fiat</option>
<option value="audi">Audi</option>
</select>
<br><br>
<input type="submit">
</form>
</body>
</html>
顯示效果:
這里需要注意的是,多選列表多選時需要按住ctrl鍵同時鼠標單擊選擇才能多選,效果如下:
到這里,已介紹了大部分的表單控件,現在你可以使用他們制作自己的表單,表單通常在動態網站中使用,這為以后制作動態網站打下基礎。
還有許多屬性沒有講到,比如html5新增的一些屬性和功能,可自行參考 w3cshool 等網站學習,感謝關注,學習愉快!
上篇 : 前端入門——html 表單
下篇: 前端入門 —— 網頁中使用窗口框架
近年來,12306的反爬越來越來嚴重,從一年前的 獲取tk參數后到現在增加了 JS、CSS等加密方式!
目前大部分人利用的登陸方式都是利用selenium ,此文也不例外。
Windows
python 3.6.5
selenium
pyautogui
time
第一步:
實例化一款瀏覽器,并進入到12306官網
driver = webdriver.Chrome()
driver.get('https://kyfw.12306.cn/otn/resources/login.html')
driver.implicitly_wait(10)
driver.maximize_window()
第二步:
點擊賬號登陸
driver.find_element_by_xpath('//*[@id="J-userName"]').send_keys('123456')
driver.find_element_by_xpath('//*[@id="J-password"]').send_keys('123456')
第三步:
在輸入框中,模擬輸入賬號密碼:
driver.find_element_by_xpath('//*[@id="J-userName"]').send_keys('123456')
driver.find_element_by_xpath('//*[@id="J-password"]').send_keys('123456')
第四步:
當賬號密碼輸入完畢后,我們應該要做的就是 模擬點擊驗證碼圖片了!
那么首先把圖片下載下來:
yzm_code = driver.find_element_by_xpath('/html/body/div[2]/div[2]/div[1]/div[2]/div[3]/div')
yzm_code.screenshot('yzm.png')
第五步:
驗證碼下載下來后就可以為所欲為了,不管是對接打碼平臺也好,自己訓練模型,或者利用代碼模擬點擊也是可以的!
前面兩種方法根本沒法講,所以這里采用第三種方式,進行模擬點擊。
在這里 說說我們需要達到的效果,驗證碼上總共有8張圖,那么我想達到的效果就是我輸入1,2,3那么程序自動點擊1,2,3三張圖片。
所以我們先獲取到每個圖片的中心點坐標,這里是有規律的,聰明人肯定一看就懂了。
我這里這個是隨便寫的:
code = input('請輸入驗證碼:')
time.sleep(5)
point_map = {
'1': '40,45',
'2': '116,53',
'4': '257,50',
'5': '40,121',
'6': '116,133',
'3': '185,52',
'7': '185,132',
'8': '257,130'}
def get_point(indexs):
indexs = indexs.split(',')
temp = []
for index in indexs:
temp.append(point_map[index])
print(temp)
return temp
temp = get_point(code)
這兩串代碼就不解釋了,很基礎的東西。最終的效果就是 輸入1,2 那么得到的是一個列表:
[ '40,45','116,53']
記住,這個坐標只是 驗證碼圖片上的坐標,不是整個屏幕的全局坐標!!!!
那么如何取全局坐標?驗證碼頂點(1206,428)+驗證碼的坐標,即全局坐標!這里的 (1206,428)請自行測試!
第六步:
模擬點擊,利用到pyautogui這個模塊。切記,利用此模塊前一定要加延遲進行畫面切換。
(此文只做方法學習,并沒有任何其它意思,正常情況都是對接打碼平臺!希望大家能學以致用,在其它的編程過程中用的到這些方法!)
for i in temp:
indexs = i.split(',')
x = int(indexs[0])
y = int(indexs[1])
pyautogui.click(1206+x, 428+y)
最后點擊登錄即可!
driver.find_element_by_xpath('//*[@id="J-login"]').click()
上周換了個D-Link無線路由器,自己實際測試這臺型號為D-Link DI-624+A機器大概一個禮拜,雖然說沒有運用所有的功能,但是不管有線、無線傳輸效率真的頗不錯的,的確會讓人很想擁有,推薦進階玩家、想升級無線網路的朋友們可以參考看看:
首先是路由器的物理線路連接,路由器后側如下圖所示INTERNET口為外網口用與連接貓的ETH口,LAN口用于連接局域網內的電腦。
2、是電腦IP地址的設置,路由器默認已近開啟DHCP服務,所以我們把電腦IP設置成自動獲取就可以了。方法是:右鍵單擊“網上鄰居”——“屬性”——右鍵單擊“本地連接”——“屬性”出現如下窗口:
點擊確定后IP地址就設置完成了。雙擊本地連接可查看是否已經獲取到IP地址。
3、登錄路由器:打開IE瀏覽器輸入路由器地址(192.168.0.1)出現如下圖的登錄窗口,默認用戶名為admin 密碼為空。輸入后點擊確定
4、登錄后在點擊左側的設置向導。
5、點擊設置向導下的聯機設定精靈,出現設置向導步驟。
6、點擊下一步:設置您的新密碼。輸入后點擊下一步。
7、設定新時區:
8、選擇網絡連接類型:這里我們選擇PPP OE撥號用戶 如下圖:
9、輸入ADSL帳號、密碼后點擊下一步:
10、無線設置 選擇安全方式WEP,WEP 加密選擇64Bit,加密方式選擇HEX:
11、點擊下一步設置完成:
到這里我們的D-Link DI-624+A無線路由器就設置完畢了,正常情況下我們就可以上網了。
不管你家是小豪宅還是大豪宅,應該都足以滿足需求!
*請認真填寫需求信息,我們會在24小時內與您取得聯系。