javascript - 如何使用js主動(dòng)觸發(fā)事件?
問題描述
https://login.taobao.com/memb...
登錄淘寶賬戶多次密碼錯(cuò)誤后,就會(huì)需要按住滑塊拖動(dòng)到右邊(如圖)。怎么用js實(shí)現(xiàn)“按住滑塊,拖動(dòng)到左右邊呢”?
問題解答
回答1:這個(gè)滑動(dòng)塊是用來檢測機(jī)器人的,如果你用腳本直接滑動(dòng)過去,它會(huì)判斷你為機(jī)器人。其實(shí)它的本質(zhì)并不是要你滑動(dòng)過去,而是檢測你在拖動(dòng)前,拖動(dòng)中,拖動(dòng)后的鼠標(biāo)行為是否符合真人特征
回答2:原生js里有個(gè) createEvent()方法,可以主動(dòng)觸發(fā)事件。例如:
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Document</title></head><body> <p onclick='alert(1)'></p> <script type='text/javascript'>var event = document.createEvent(’MouseEvents’);event.initMouseEvent(’click’, true, true, document.defaultView, 0, 0, 0, 0, 0, false, false, false, false, 0 ,null);aaa.dispatchEvent(event); </script></body></html>
你可以根據(jù)自己將click換成mousemove。
回答3:看圖,該滾動(dòng)條初始化是一個(gè)span也就是你圈的部分,還有一個(gè)p用于顯示拖動(dòng)進(jìn)度。如果你是問的只是針對達(dá)到它的驗(yàn)證在拖動(dòng)該span的時(shí)候該span的left和p.nc_1__bg的width發(fā)生改變,這時(shí)嘗試主動(dòng)修改這兩個(gè)style,值都設(shè)為258px,然后點(diǎn)擊(或者說mousedown、mouseup)該span,發(fā)現(xiàn)能夠完成驗(yàn)證。
思路:修改style,然后觸發(fā)span的click、mousedown、mouseup事件,因?yàn)椴淮_定它具體是綁定在up還是down事件中(根據(jù)初步操作,應(yīng)該是綁定在鼠標(biāo)按下事件中),所以都觸發(fā)一遍,至于click只是為了防漏.代碼: 修改樣式:就是修改p的width和span的left為258px,這里略過。 js:$(’#nc_1_wrapper #nc_1_n1z’).click(); //觸發(fā)單擊事件 $(’#nc_1_wrapper #nc_1_n1z’).mousedown(); //觸發(fā)鼠標(biāo)按下事件 $(’#nc_1_wrapper #nc_1_n1z’).mouseup(); //觸發(fā)鼠標(biāo)彈起事件回答4:
其實(shí)就是模擬鼠標(biāo)抬起到時(shí)候就行判斷
相關(guān)文章:
1. javascript - 有適合開發(fā)手機(jī)端Html5網(wǎng)頁小游戲的前端框架嗎?2. html - eclipse 標(biāo)簽錯(cuò)誤3. python - Pycharm的Debug用不了4. Python中使用超長的List導(dǎo)致內(nèi)存占用過大5. python - pandas按照列A和列B分組,將列C求平均數(shù),怎樣才能生成一個(gè)列A,B,C的dataframe6. 安全性測試 - nodejs中如何防m(xù)ySQL注入7. javascript - JS變量被清空8. java - 在用戶不登錄的情況下,用戶如何添加保存到購物車?9. javascript - axios請求回來的數(shù)據(jù)組件無法進(jìn)行綁定渲染10. javascript - 關(guān)于apply()與call()的問題
