<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
const pasteImageRef = useRef<HTMLDivElement>(null); useEffect(()=>{ //給元件新增監聽貼上事件 pasteImageRef.current?.addEventListener('paste', pasteHandler); },[]); <div tabIndex={-1} // 設定tabIndex才可以聚焦 ref={pasteImageRef} > <span>Ctrl+V 貼上截圖</span> </div>
const pasteHandler = (e: ClipboardEvent) => { const { clipboardData } = e; const { items } = clipboardData; const { length } = items; let blob = null; for (let i = 0; i < length; i++) { const item = items[i]; if (item.type.startsWith('image')) { blob = item.getAsFile(); // blob中就是截圖的檔案,獲取後可以上傳到伺服器 } } };
新增事件監聽
window.addEventListener('scroll', this.handleListen)
移除事件監聽
window.removeEventListener('scroll', this.handleListen)
繫結是事件函數必須是同一個,如果不會同一個,會導致解綁失敗。
一般會用到的事件函數型別有三種:命名函數、箭頭函數、匿名函數
這裡重點是新增處理的函數,addEventListener()和removeEventListener()新增的處理常式必須是同一個函數,什麼叫同一個函數呢,就是說這兩個函數時相等的,指向同一個地址。
1. 匿名函數
匿名函數在事件繫結中的新增與移除
window.addEventListener('scroll', function(e){ console.log(e) }); window.removeEventListener('scroll', function(e){ console.log(e) });
從上面的範例寫法來說,很明顯新增和移除事件時因為使用的是匿名函數,所以會返回兩個不同的地址,這兩個事件不同,所以無法移除事件
2. 命名函數
命名函數在事件繫結中的新增與移除
handleScroll(){ // 一些程式碼 } window.addEventListener('scroll', this.handleScroll.bind(this)); window.removeEventListener('scroll', this.handleScroll.bind(this));
以上是常用的使用命名函數的寫法,但其實這樣寫還是不對的,每次加上bind之後返回的函數並不是指向同一個函數
const test = { name:'test', getName:function(){ console.log(this.name) } } let func1 = test.getName.bind(test); let func2 = test.getName.bind(test); let func3 = test.getName; let func4 = test.getName; console.log(func1==func2) console.log(func3==func4)
如果還想要用命名函數,那麼就要換種寫法,解決方法是先在constructor中提前宣告好
constructor(){ super(); this.handleScroll = this.handleScroll.bind(this) } handleScroll(){ // 一些程式碼 } window.addEventListener('scroll', this.handleScroll); window.removeEventListener('scroll', this.handleScroll);
3. 箭頭函數
可以直接使用箭頭函數來避免返回的不是同一個函數這種情況
箭頭函數在事件繫結中的新增與移除
handleScroll = () => { // 一些程式碼 } window.addEventListener('scroll', this.handleScroll); window.removeEventListener('scroll', this.handleScroll);
target.addEventListener(type, listener, options); target.addEventListener(type, listener, useCapture);
target
可以有兩種,window和自定義物件
1.window.addEventListener('scroll', this.handleScroll); 2.const obj = document.getElementsByClassName(classname)[0]; obj.addEventListener('scroll', this.handleScroll);
type
表示監聽事件型別的字串
一般常用的是滑鼠事件(‘click’, ‘dblclick’)和鍵盤事件(‘keydown’, ‘keypress’)等
listener
當所監聽的事件型別觸發時,會接收到一個事件通知(實現了 Event 介面的物件)物件。listener 必須是一個實現了 EventListener 介面的物件,或者是一個函數。
options
(可選)一個指定有關 listener 屬性的可選引數物件。可用的選項如下:
capture
: Boolean,表示 listener 會在該型別的事件捕獲階段傳播到該 EventTarget 時觸發。once
: Boolean,表示 listener 在新增之後最多隻呼叫一次。如果是 true, listener 會在其被呼叫之後自動移除。passive
: Boolean,設定為true時,表示 listener 永遠不會呼叫preventDefault()。如果 listener 仍然呼叫了這個函數,使用者端將會忽略它並丟擲一個控制檯警告。addEventListener(type, listener, { capture: false, once: false, passive: false })
useCapture
(可選)Boolean,在DOM樹中,註冊了listener的元素, 是否要先於它下面的EventTarget,呼叫該listener。
當useCapture(設為true) 時,沿著DOM樹向上冒泡的事件,不會觸發listener。當一個元素巢狀了另一個元素,並且兩個元素都對同一事件註冊了一個處理常式時,所發生的事件冒泡和事件捕獲是兩種不同的事件傳播方式。
addEventListener(type, listener, false)
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45