前端學習-事件對象與典型案例(二十六)

目錄

前言

事件對象

目標

事件對象是什么

語法

獲取事件對象

部分常用屬性

示例代碼

示例代碼:評論回車發布

總結


前言

長風破浪會有時,直掛云帆濟滄海。


事件對象

目標

能說出什么是事件對象

事件對象是什么

也是個對象,這個對象里有事件觸發時的相關信息例如:鼠標點擊事件中,事件對象就存了鼠標點在哪個位置等信息

使用場景可以判斷用戶按下哪個鍵,比如按下回車鍵可以發布新聞

可以判斷鼠標點擊了哪個元素,從而做相應的操作

語法

如何獲取

在事件綁定的回調函數的第一個參數就是事件對象

一般命名為event,ev,e

元素.addEventListener('click',function(e){}//e為事件對象

獲取事件對象

目標:能夠使用常見事件對象屬性

部分常用屬性

type口 獲取當前的事件類型>

clientX/clientY口 獲取光標相對于瀏覽器可見窗口左上角的位置>

offsetX/offsetY獲取光標相對于當前DOM元素左上角的位置 key口 用戶按下的鍵盤鍵的值口 現在不提倡使用keyCode

示例代碼

<!DOCTYPE html>
<html lang="en">
?
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
?
<body><button>按鈕</button><script>const btn = document.querySelector('button');btn.addEventListener('click', function (e) {console.log(e.type);});</script>
</body>
?
</html>

示例代碼:評論回車發布

<!DOCTYPE html>
<html lang="en">
?
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Input Box</title><style>body {font-family: Arial, sans-serif;}
?.input-container {display: flex;justify-content: space-between;align-items: flex-start;margin-bottom: 10px;width: 500px;}
?textarea {width: 70%;height: 100px;padding: 10px;border: 1px solid #ccc;border-radius: 5px;resize: none;position: relative;/* 設置相對定位,以便偽元素可以絕對定位 */box-sizing: border-box;/* 確保內邊距和邊框包含在寬度內 */}
?textarea::after {content: '龐嘉欣專屬評論框';/* 偽元素內容 */position: absolute;/* 絕對定位 */bottom: 5px;/* 距離底部 5px */right: 5px;/* 距離右側 5px */font-size: 0.8em;/* 字體大小 */color: #888;/* 字體顏色 */pointer-events: none;/* 確保偽元素不影響交互 */z-index: 1;/* 確保偽元素在內容之上 */}
?.button-counter-container {display: flex;flex-direction: column;align-items: flex-end;}
?button {padding: 20px 20px;background-color: #007bff;color: white;border: none;border-radius: 5px;cursor: pointer;margin-bottom: 10px;margin-right: 40px;margin-top: 10px;}
?.counter {text-align: right;margin-right: 50px;margin-top: 25px;}
?.counter span {font-weight: bold;}
?#comments-container {margin-top: 20px;width: 500px;}
?.comment {margin-bottom: 10px;padding: 10px;border: 1px solid rgba(0, 0, 0, 0.5);border-radius: 5px;background-color: #ffffff;}
?.comment-time {font-size: 0.9em;color: #888;margin-top: 5px;display: flex;justify-content: space-between;align-items: center;}
?.comment-time span {font-size: 0.8em;color: #888;}</style>
</head>
?
<body><div class="input-container"><textarea id="input-text" placeholder="發布一條友善的評論"></textarea><div class="button-counter-container"><button id="submit-button">發布</button><div class="counter"><span id="current-count">0</span>/200字</div></div></div>
?<div id="comments-container"></div>
?<script>document.addEventListener('DOMContentLoaded', function () {const inputText = document.getElementById('input-text');const currentCount = document.getElementById('current-count');const submitButton = document.getElementById('submit-button');const commentsContainer = document.getElementById('comments-container');
?inputText.addEventListener('input', function () {const count = inputText.value.length;currentCount.textContent = count;});
?function addComment() {const commentText = inputText.value.trim();if (commentText) {const now = new Date();const formattedTime = now.toLocaleString();
?const commentElement = document.createElement('div');commentElement.className = 'comment';
?const commentContent = document.createElement('span');commentContent.textContent = commentText;
?const commentTime = document.createElement('div');commentTime.className = 'comment-time';
?const timeSpan = document.createElement('span');timeSpan.textContent = formattedTime;
?const signatureSpan = document.createElement('span');signatureSpan.textContent = '^-^';signatureSpan.style.fontSize = '0.8em';signatureSpan.style.color = '#87CEEB';
?commentTime.appendChild(timeSpan);commentTime.appendChild(signatureSpan);
?commentElement.appendChild(commentContent);commentElement.appendChild(commentTime);
?commentsContainer.appendChild(commentElement);
?inputText.value = '';currentCount.textContent = '0';}}
?submitButton.addEventListener('click', addComment);
?inputText.addEventListener('keydown', function (event) {if (event.key === 'Enter' && !event.shiftKey) {event.preventDefault();addComment();}});});</script>
</body>
?
</html>


總結

千磨萬擊還堅勁,任爾東西南北風。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/65801.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/65801.shtml
英文地址,請注明出處:http://en.pswp.cn/web/65801.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Playwright vs Selenium:全面對比分析

在現代軟件開發中&#xff0c;自動化測試工具在保證應用質量和加快開發周期方面發揮著至關重要的作用。Selenium 作為自動化測試領域的老牌工具&#xff0c;長期以來被廣泛使用。而近年來&#xff0c;Playwright 作為新興工具迅速崛起&#xff0c;吸引了眾多開發者的關注。那么…

Windows 程序設計3:寬窄字節的區別及重要性

文章目錄 前言一、寬窄字節簡介二、操作系統及VS編譯器對寬窄字節的編碼支持1. 操作系統2. 編譯器 三、寬窄字符串的優缺點四、寬窄字節數據類型總結 前言 Windows 程序設計3&#xff1a;寬窄字節的區別及重要性。 一、寬窄字節簡介 在C中&#xff0c;常用的字符串指針就是ch…

進階——十六屆藍橋杯嵌入式熟練度練習(LED的全開,全閉,點亮指定燈,交替閃爍,PWM控制LED呼吸燈)

點亮燈的函數 void led_show(unsigned char upled) { HAL_GPIO_WritePin(GPIOC,GPIO_PIN_All,GPIO_PIN_SET); HAL_GPIO_WritePin(GPIOC,upled<<8,GPIO_PIN_RESET); HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_SET); HAL_GPIO_WritePin(GPIOD,GPIO_PIN_2,GPIO_PIN_RE…

力扣 最大子數組和

動態規劃&#xff0c;前綴和&#xff0c;維護狀態更新。 題目 從題可以看出&#xff0c;找的是最大和的連續子數組&#xff0c;即一個數組中的其中一個連續部分。從前往后遍歷&#xff0c;每遍歷到一個數可以嘗試做疊加&#xff0c;注意是嘗試&#xff0c;因為有可能會遇到一個…

Homestyler 和 Tripo AI 如何利用人工智能驅動的 3D 建模改變定制室內設計

讓設計夢想照進現實 在Homestyler,我們致力于為每一個夢想設計師提供靈感的源泉,而非挫折。無論是初學者打造第一套公寓,或是專業設計師展示作品集,我們的直觀工具都能讓您輕松以驚人的3D形式呈現空間。 挑戰:實現定制設計的新紀元 我們知道,將個人物品如傳家寶椅子、…

如何當前正在運行的 Elasticsearch 集群信息

要查看當前正在運行的 Elasticsearch 集群信息&#xff0c;可以通過以下幾種方法&#xff1a; 1. 使用 _cluster/health API _cluster/health API 返回集群的健康狀態、節點數量、分片狀態等信息。可以用 curl 命令直接訪問&#xff1a; curl -X GET "http://localhost…

算法練習4——一個六位數

這道題特別妙 大家仔細做一做 我這里采用的是動態規劃來解這道題 結合題目要求找出數與數之間的規律 抽象出狀態轉移方程 題目描述 有一個六位數&#xff0c;其個位數字 7 &#xff0c;現將個位數字移至首位&#xff08;十萬位&#xff09;&#xff0c;而其余各位數字順序不…

client-go 的 QPS 和 Burst 限速

1. 什么是 QPS 和 Burst &#xff1f; 在 kubernetes client-go 中&#xff0c;QPS 和 Burst 是用于控制客戶端與 Kubernetes API 交互速率的兩個關鍵參數&#xff1a; QPS (Queries Per Second) 定義&#xff1a;表示每秒允許發送的請求數量&#xff0c;即限速器的平滑速率…

B-tree 數據結構詳解

1. 引言 1.1 什么是 B-tree&#xff1f; B-tree&#xff08;Balanced Tree&#xff0c;平衡樹&#xff09;是一種自平衡的多路搜索樹數據結構&#xff0c;其核心特性包括&#xff1a; 多路性&#xff1a; 每個節點可以包含多個關鍵字和子節點&#xff0c;而非僅二分。平衡性…

Python 正則表達式完全指南

# Python 正則表達式完全指南 正則表達式&#xff08;Regular Expression&#xff09;是Python中進行文本處理的強大工具。本指南將詳細介紹Python中正則表達式的使用方法和實踐技巧。 ## 1. 基礎知識 ### 1.1 導入正則表達式模塊 python import re ### 1.2 創建正則表達式 在…

Vue的scoped原理是什么

CSS常見模塊化方案 BEM&#xff08;Block Element Modifier&#xff09;: BEM是一種流行的命名約定&#xff0c;它通過特定的命名規則來組織CSS類名&#xff0c;使得樣式具有模塊化、可重用性和可讀性。BEM的命名規則是&#xff1a;block__element--modifier。 block&#xf…

【LC】3270. 求出數字答案

題目描述&#xff1a; 給你三個 正 整數 num1 &#xff0c;num2 和 num3 。 數字 num1 &#xff0c;num2 和 num3 的數字答案 key 是一個四位數&#xff0c;定義如下&#xff1a; 一開始&#xff0c;如果有數字 少于 四位數&#xff0c;給它補 前導 0 。答案 key 的第 i 個數…

太原理工大學軟件設計與體系結構 --javaEE

這個是簡答題的內容 選擇題的一些老師會給你們題庫&#xff0c;一些注意的點我會做出文檔在這個網址 項目目錄預覽 - TYUT復習資料:復習資料 - GitCode 希望大家可以給我一些打賞 什么是Spring的IOC和DI IOC 是一種設計思想&#xff0c;它將對象的創建和對象之間的依賴關系…

深度學習知識點:LSTM

文章目錄 1.應用現狀2.發展歷史3.基本結構4.LSTM和RNN的差異 1.應用現狀 長短期記憶神經網絡&#xff08;LSTM&#xff09;是一種特殊的循環神經網絡(RNN)。原始的RNN在訓練中&#xff0c;隨著訓練時間的加長以及網絡層數的增多&#xff0c;很容易出現梯度爆炸或者梯度消失的問…

mmdet

一&#xff0c;configs/_base_ 1.default_runtime.py 2.schedule_1x.py 二&#xff0c;mmdet 1.datasets/coco.py/CocoDataset METAINFO {classes:(milk, red, spring, fanta, sprite, pepsi, king, ice, cola, scream ),# palette is a list of color tuples, which is us…

ElasticSearch 認識和安裝ES

文章目錄 一、為什么學ElasticSearch?1.ElasticSearch 簡介2.ElasticSearch 與傳統數據庫的對比3.ElasticSearch 應用場景4.ElasticSearch 技術特點5.ElasticSearch 市場表現6.ElasticSearch 的發展 二、認識和安裝ES1.認識 Elasticsearch&#xff08;簡稱 ES&#xff09;2.El…

node.js中實現token的生成與驗證

Token&#xff08;令牌&#xff09;是一種用于在客戶端和服務器之間安全傳輸信息的加密字符串。在Web開發中&#xff0c;Token常用于身份驗證和授權&#xff0c;確保用戶能夠安全地訪問受保護的資源。 作用與意義 身份驗證&#xff1a;Token可以用來驗證用戶的身份&#xff0…

第34天:安全開發-JavaEE應用反射機制攻擊鏈類對象成員變量方法構造方法

時間軸&#xff1a; Java反射相關類圖解&#xff1a; 反射&#xff1a; 1、什么是 Java 反射 參考&#xff1a; https://xz.aliyun.com/t/9117 Java 提供了一套反射 API &#xff0c;該 API 由 Class 類與 java.lang.reflect 類庫組成。 該類庫包含了 Field 、 Me…

Django后端相應類設計

通用的ApiResponse類&#xff1a;用于生成統一的 API 響應格式。每個響應都包含以下字段&#xff08;每個接口最終的返回數據格式&#xff09;&#xff1a; status_code&#xff1a;HTTP 狀態碼&#xff08;如 200、400、500 等&#xff09;message&#xff1a;響應的描述信息…

汽車基礎軟件AutoSAR自學攻略(三)-AutoSAR CP分層架構(2)

汽車基礎軟件AutoSAR自學攻略(三)-AutoSAR CP分層架構(2) 下面我們繼續來介紹AutoSAR CP分層架構&#xff0c;下面的文字和圖來自AutoSAR官網目前最新的標準R24-11的分層架構手冊。該手冊詳細講解了AutoSAR分層架構的設計&#xff0c;下面讓我們來一起學習一下。 Introductio…