javascript - 如何使用js主動觸發(fā)事件?
問題描述
https://login.taobao.com/memb...
登錄淘寶賬戶多次密碼錯誤后,就會需要按住滑塊拖動到右邊(如圖)。怎么用js實現“按住滑塊,拖動到左右邊呢”?
問題解答
回答1:這個滑動塊是用來檢測機器人的,如果你用腳本直接滑動過去,它會判斷你為機器人。其實它的本質并不是要你滑動過去,而是檢測你在拖動前,拖動中,拖動后的鼠標行為是否符合真人特征
回答2:原生js里有個 createEvent()方法,可以主動觸發(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>
你可以根據自己將click換成mousemove。
回答3:看圖,該滾動條初始化是一個span也就是你圈的部分,還有一個p用于顯示拖動進度。如果你是問的只是針對達到它的驗證在拖動該span的時候該span的left和p.nc_1__bg的width發(fā)生改變,這時嘗試主動修改這兩個style,值都設為258px,然后點擊(或者說mousedown、mouseup)該span,發(fā)現能夠完成驗證。
思路:修改style,然后觸發(fā)span的click、mousedown、mouseup事件,因為不確定它具體是綁定在up還是down事件中(根據初步操作,應該是綁定在鼠標按下事件中),所以都觸發(fā)一遍,至于click只是為了防漏.代碼: 修改樣式:就是修改p的width和span的left為258px,這里略過。 js:$(’#nc_1_wrapper #nc_1_n1z’).click(); //觸發(fā)單擊事件 $(’#nc_1_wrapper #nc_1_n1z’).mousedown(); //觸發(fā)鼠標按下事件 $(’#nc_1_wrapper #nc_1_n1z’).mouseup(); //觸發(fā)鼠標彈起事件回答4:
其實就是模擬鼠標抬起到時候就行判斷
相關文章:
1. bootstrp是col-md-12列的,只有col-md-10有內容,可以讓沒有內容的不占據位置嗎;2. java - 如何用圖畫的方式有效地表示多線程?3. thinkPHP5中獲取數據庫數據后默認選中下拉框的值,傳遞到后臺消失不見。有圖有代碼,希望有人幫忙4. python - Fiddler+Android模擬器抓取app,json數據被加密了,如何解析?5. 常量在外面不加引號會報錯。6. sublime text3安裝package control失敗7. python 3.4 error: Microsoft Visual C++ 10.0 is required8. 百度地圖 - Android app中準備接入地圖sdk,百度VS高德哪個好一點?9. wordpress里,這樣的目錄列表是屬于小工具還是啥?10. 我的怎么不顯示啊,話說有沒有QQ群什么的
