用js模擬鍵盤輸入


從目前找到的資料來看,這個模擬不能起到所有的作用,主要體現在鍵盤的有一些事件不能完整的體現 出來

先做個記錄吧。

//這個就是用來輸入字科符的
 var inpEle=document.getElementById("stockCode");
 var st ='000001'
  var evt = new InputEvent('input', {
    inputType: 'insertText',
    data: st,
    dataTransfer: null,
    isComposing: false
  });
  inpEle.value = st;
  inpEle.dispatchEvent(evt);
//敲回車
let keyCoke = 13
let keyboardEvent = document.createEvent('KeyboardEvent')
let initMethod = typeof keyboardEvent.initKeyboardEvent !== 'undefined' ? 'initKeyboardEvent' : 'initKeyEvent'
keyboardEvent[initMethod]('keyup', true, true, window, false, false, false, false, keyCoke, 0)
document.getElementById('stockCode').dispatchEvent(keyboardEvent)
//不知道為什么弄的那個網站還得這樣處理一下

function fireKeyEvent(el, evtType, keyCode) {
  var evtObj;
  if (document.createEvent) {
       
          evtObj = document.createEvent('UIEvents');
          evtObj.initUIEvent(evtType, true, true, window, 1);
 
          delete evtObj.keyCode;
          if (typeof evtObj.keyCode === "undefined") {//為了模擬keycode
              Object.defineProperty(evtObj, "keyCode", { value: keyCode });                       
          } else {
              evtObj.key = String.fromCharCode(keyCode);
          }
 
          if (typeof evtObj.ctrlKey === 'undefined') {//為了模擬ctrl鍵
              Object.defineProperty(evtObj, "ctrlKey", { value: true });
          } else {
              evtObj.ctrlKey = true;
          }
      el.dispatchEvent(evtObj);
      }
}
 fireKeyEvent(document.getElementById('stockCode'),'keyup',13)  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM