第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

如何將 jQuery 代碼轉(zhuǎn)換為 JavaScript?

如何將 jQuery 代碼轉(zhuǎn)換為 JavaScript?

瀟湘沐 2022-12-22 12:58:10
查詢(xún):var isResizing = false,    lastDownX = 0;$(function () {    var container = $('#container'),        top = $('#top-panel'),        handle = $('#drag');    handle.on('mousedown', function (e) {        isResizing = true;        lastDownX = e.clientY;    });    $(document).on('mousemove', function (e) {        // we don't want to do anything if we aren't resizing.        if (!isResizing)             return;        var offsetRight = top.height() + (e.clientY - container.offset().top);        top.css('top', offsetRight);    }).on('mouseup', function (e) {        // stop resizing        isResizing = false;    });});腳本:var isResizing = false// eslint-disable-next-line no-unused-varsvar lastDownX = 0function resizeVerticallyInit () {  var top = document.querySelector('#topology-container')  var handle = document.querySelector('#drag')  handle.addEventListener('mousedown', function (e) {    isResizing = true    lastDownX = e.clientY  })  document.addEventListener('mousemove', function (e) {    // we don't want to do anything if we aren't resizing.    if (!isResizing) {      return    }    var offsetRight = top.height() + 20    document.querySelector('#topology-container').style.top = offsetRight  })  document.addEventListener('mouseup', function (e) {    // stop resizing    isResizing = false  })}mounted () {  ...  resizeVerticallyInit()}如您所見(jiàn),我在 mounted() 生命周期方法中的 Vue.js 組件中使用了 JavaScript 函數(shù)。我試圖轉(zhuǎn)換它,但它不起作用。首先我需要說(shuō):// eslint-disable-next-line no-unused-varsvar lastDownX = 0我不知道為什么它會(huì)抱怨 lastDownX 未被使用。第二個(gè)是錯(cuò)誤:"[Vue warn]: Error in mounted hook: "TypeError: Cannot read property 'addEventListener' of null"它抱怨:  handle.addEventListener('mousedown', function (e) {    isResizing = true    lastDownX = e.clientY  })有人可以幫忙轉(zhuǎn)換嗎?
查看完整描述

1 回答

?
紫衣仙女

TA貢獻(xiàn)1839條經(jīng)驗(yàn) 獲得超15個(gè)贊

如果元素不存在于 DOM 中,則First ofdocument.querySelector方法將返回。null您不能調(diào)用addEventListenernull。它之所以起作用,jQuery是因?yàn)?jquery 構(gòu)造了一個(gè)單獨(dú)的對(duì)象(稱(chēng)為 jQuery 對(duì)象)。一個(gè) jQuery 對(duì)象看起來(lái)有點(diǎn)像這樣:


{

  0: {...} // HTMLElement reference

  length: 1

} // jQuery object

該對(duì)象公開(kāi)了一個(gè) jQuery API,它具有on事件處理方法(無(wú)論是否存在實(shí)際 DOM 元素都可用)。這是 jQuery 的優(yōu)點(diǎn)(也是缺點(diǎn))。


另一方面,查詢(xún)選擇器方法返回HTMLElement. 如果該元素不存在于 DOM 中,則null返回。


現(xiàn)在假設(shè)該元素將在一定時(shí)間后出現(xiàn)在 DOM 中,您可以做兩件事:


等待元素出現(xiàn)在 DOM 中,一旦它可用,就添加一個(gè)監(jiān)聽(tīng)器函數(shù)。

在 JavaScript 中使用live事件(事件委托)。

我將向您展示第二種方法:

setTimeout(() => {

  document.querySelector('#container').innerHTML = `<button id="btn">Click</button>`;

}, 3000);


document.addEventListener('click', (e) => {

  if (e.target.id === 'btn') {

    alert('Click works!');

  }

});

<div id="container">

  A button will appear after 3 seconds. However, click event would still work.

</div>

如您所見(jiàn),我正在使用e.target它來(lái)檢測(cè)我在文檔中單擊了哪個(gè)元素(我附加了偵聽(tīng)器的位置)。一旦條件匹配,它就會(huì)觸發(fā)alert. 這允許我們?yōu)樽畛醪淮嬖谟?DOM 中的元素綁定事件。



查看完整回答
反對(duì) 回復(fù) 2022-12-22
  • 1 回答
  • 0 關(guān)注
  • 119 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)