2、事件機制、DOM操作、jquery對尺寸操作、jquery添加和刪除

一、事件機制

1、事件源.事件類型(事件處理程序)

$(this)中的this不能加引號

$('#box').click(function () {$(this).css('background-color','blue')//點擊顏色變為藍色
})

2、事件源.on/bind(事件類型,事件處理程序)

$("#box").on('dbclick',function () {$(this).css('border-radius','100px')
})
$('#box').bind('mouseover',function () {$(this).csss('font-size','60px')
})

3、事件源.on/bind({事件類型1:事件處理程序1,事件類型2:事件處理程序2,})

$('#box').on({ //用on或bindmousedown: function () {//按下鼠標console.log("鼠標按下了")},mouseup: function () {//抬起鼠標console.log("鼠標抬起了")}
})

區別.on()與.bind():

  • 與 .bind() 不同的是,.on() 方法可以附加額外的參數,如可選的選擇器,用于對事件目標進行過濾。這樣,您可以只在滿足選擇器條件的元素上觸發事件處理程序。

4、事件對象

event不用考慮兼容性 輸出必須要event.屬性

$("#box").on({mouseenter: function () {
//MouseEvent {isTrusted: true, screenX: 168, screenY: 178, clientX: 127 …}console.log(event)console.log('pageX:' + event.pageX)//距離瀏覽器左邊的橫坐標 包括滾動條卷去的console.log('clientX:' + event.clientX)//距離瀏覽器左邊的橫坐標},
})
$('#user').bind('keyup', function () {console.log(event);//如果按下enter就跳轉頁面if(event.keyCode == 13 && event.key == 'Enter') {window.location.href = "https://www.***.com"}
})

5、each() 函數用于遍歷的對象和數組。

$('#btn').click(function () {console.log($("ul>li"));$('ul>li').each(function () {console.log($(this).text()// 輸出每個列表項的文本內容})
})
image-20240302163458915

6、jQuery.each(數組/對象,回調函數(key,value)) 遍歷數組或者對象

遍歷數組

var arr = ['web', '前端']
//遍歷數組   key  value也可以
$.each(arr, function (index, item) {
//數組的索引是0,值是web 數組的索引是1,值是前端 console.log('數組的索引是' + index + ',值是' + item)
})

遍歷對象

var obj = { name: "小明", age: 20, sex: "男" }
$.each(obj, function (index, item) {
//屬性名:name,屬性值:小明  屬性名:age,屬性值:20  屬性名:sex,屬性值:男console.log("屬性名:" + index + ",屬性值:" + item)
})

二、DOM操作

1、 html()獲取或設置被選元素的所有節點

  • 相當于innerHTML
console.log($('#box').html());
//<p>哈哈哈</p>   <!-- 我是注釋 -->  都可以獲取到
$("#btn").on('click',function(){$("#box").html("<a>我是超鏈接</a><!-- 我是注釋的升級版 -->")
})

image-20240302165555873

2、text()設置或返回所選元素的內容

  • 相當于innerText
console.log($('#box').text())//返回內容
$('#btn').bind('mouseover', function () {$('#box').text('段落標簽')//改變內容為段落標簽
})

3、val()設置或返回表單字段的值

<input type="text" id="user" value="我是輸入框的文本">
console.log($('#user').val())//返回 我是輸入框的文本
$('#user').on({click: function () {$(this).val('web31')//點擊以后  值變為 web31}
})

4、attr()prop()獲取或者設置被選元素的屬性,參數是屬性名和屬性值

區別1:

  • attr() 不僅可以獲取和設置元素的本身屬性和設置元素的自定義屬性
  • prop()只能設置元素的本身屬性

區別2:

  • 表單中的一些屬性disabled/selected/checked用prop()
<p class="text" name_1="proName">我是盒子box中的段落文本text</p>
console.log($('.text').attr('class')) //text  獲取類名為text的class為
console.log($('.text').prop('class')) //text  獲取類名為text的class為
//proName  獲取類名為text的name_1為 
console.log($('.text').attr('name_1'))//proName
console.log($('.text').prop('name_1')) //undefined  prop不能獲取自定義屬性
$('#btnSet').click(function () {console.log($(this).attr('disabled')) //undefined 表單中的不能用attrconsole.log($(this).prop('disabled'))//flase
})

三、jquery對尺寸操作

1、width()height()方法

  • 設置或返回元素的寬度高度
  • 相當于 style.width()
    元素本身大小
console.log($('#child').width())//返回元素的寬度
console.log($('#child').height())
$('button').click(function () {$('#child').width('400px')//點擊以后 將元素的寬度改為400px$('#child').height('300px')
})

2、innerWidth()innerHeight()

  • 相當于clientWidth() / clientHeight()
    元素本身 + padding
console.log($('#child').innerWidth())
console.log($('#child').innerHeight())

3、outerWidth()outerHeight()

  • 相當于offsetWidth offsetHeight
    元素本身 + padding + border
console.log($('#child').outerWidth())
console.log($('#child').outerHeight())

4、scrollTop()scrollLeft()

  • 方法設置或者返回滾動條被卷去的元素的高度
  • scrollLeft() 方法設置或者返回滾動條被卷去的元素的寬度
$(window).scroll(function () {
// console.log($(window).scrollTop())
console.log($(window).scrollLeft())
})
$('#set').click(function () {$(window).scrollTop(600)//點擊按鈕  滾動條卷去600px
})

四、jQuery添加和刪除元素

1、append() 結尾插入(選擇的元素內部)

$("#add").click(function () {console.log($("#parent").append("<li>我是添加的元素</li>"));
})

image-20240302184220947

2、prepend() 開頭插入(選擇的元素內部)

$("#add").click(function () {console.log($("#parent").prepend("<li>我是添加的元素</li>"));
})

image-20240302184327646

3、after() 之后插入 (該元素的外面)

$("#add").click(function () {console.log($("#parent").after("<li>我是添加的元素</li>"));
})

image-20240302184421427

4、before() 之前插入 (該元素的外面)

$("#add").click(function () {console.log($("#parent").before("<li>我是添加的元素</li>"));
})

image-20240302184507756

5、remove() 刪除元素 (包括自己)

  • 刪除自己和自己的子元素
  • 刪除以后不占位置
$("#add").click(function () {console.log($("#parent").remove());
})

6、empty() 刪除元素(自己本身不刪除)

  • 刪除自己的子元素
  • 自己本身不刪除
$("#add").click(function () {console.log($("#parent").empty());
})//parent不刪除  里面的都刪除

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

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

相關文章

適配器模式在微服務的巧妙應用

適配器模式&#xff08;Adapter Pattern&#xff09;是一種結構型設計模式&#xff0c;它允許不兼容的接口之間可以一起工作。適配器模式通常用于將一個類的接口轉換成客戶端期望的另一種接口&#xff0c;從而使原本因接口不兼容而不能一起工作的類可以一起工作。 適配器模式的…

使用Haproxy搭建Web群集

Hapraxy是目前比較流行的一種群集調度工具&#xff0c;同類群集調度工具有很多&#xff0c;如LVS 和Nginx。相 比較而言&#xff0c;LVS.性能最好&#xff0c;但是搭建相對復雜:Nginx的 upstream 模塊支持群集功能&#xff0c;但是對群集節 點健康檢查功能不強&#xff0c;性能…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的番茄成熟度檢測系統(Python+PySide6界面+訓練代碼)

摘要&#xff1a;開發番茄成熟度檢測系統對于提高農業產量和食品加工效率具有重大意義。本篇博客詳細介紹了如何利用深度學習構建一個番茄成熟度檢測系統&#xff0c;并提供了完整的實現代碼。該系統基于強大的YOLOv8算法&#xff0c;并結合了YOLOv7、YOLOv6、YOLOv5的對比&…

騰訊云幻獸帕魯服務器使用Linux和Windows操作系統,對用戶的技術要求有何不同?

騰訊云幻獸帕魯服務器使用Linux和Windows操作系統對用戶的技術要求有何不同&#xff1f; 首先&#xff0c;從操作界面的角度來看&#xff0c;Windows操作系統相對簡單易操作&#xff0c;適合那些偏好使用圖形化界面操作的用戶。而Linux操作系統則需要通過命令行完成&#xff0…

百度搜索引擎SEO優化方法

隨著互聯網的不斷發展&#xff0c;搜索引擎已經成為人們獲取信息、產品和服務的主要途徑之一。而在中國&#xff0c;百度作為最大的搜索引擎&#xff0c;其影響力不可忽視。了解并掌握百度SEO關鍵詞優化方法&#xff0c;對于提升網站在搜索引擎中的排名至關重要。 關鍵詞選擇&a…

數據結構——跳表

簡單介紹跳表 跳表&#xff08;Skip List&#xff09;是一種可以進行對數級別查找的數據結構&#xff0c;它通過在數據中構建多級索引來提高查詢效率。跳表是一種基于鏈表的隨機化數據結構&#xff0c;其本質是由多個鏈表組成&#xff0c;每個鏈表中的元素都是原始鏈表中的元素…

圖論 - Trie樹(字符串統計、最大異或對)

文章目錄 前言Part 1&#xff1a;Trie字符串統計1.題目描述輸入格式輸出格式數據范圍輸入樣例輸出樣例 2.算法 Part 2&#xff1a;最大異或對1.題目描述輸入格式輸出格式數據范圍輸入樣例輸出樣例 2.算法 前言 本篇博客將介紹Trie樹的常見應用&#xff0c;包括&#xff1a;Trie…

C++ 使用 nlohmann::json存儲json文件

C 使用 nlohmann::json存儲json文件 nlohmann::json 概述JSON 存儲的示例以追加的方式存儲json文件 nlohmann::json 概述 nlohmann::json 是 C 中一個流行的 JSON 庫&#xff0c;由 Niels Lohmann 開發。它提供了一個簡單而強大的 API&#xff0c;用于解析、構建、操作和序列化…

電子電氣架構——車載以太網協議棧

電子電氣架構——車載以太網協議棧 我是穿拖鞋的漢子&#xff0c;魔都中堅持長期主義的汽車電子工程師。 老規矩&#xff0c;分享一段喜歡的文字&#xff0c;避免自己成為高知識低文化的工程師&#xff1a; 沒有人關注你。也無需有人關注你。你必須承認自己的價值&#xff0c…

MySQL入門------數據庫與SQL概述

目錄 前言 一、數據庫相關概念 二、數據模型 1.關系型數據庫&#xff08;RDBMS&#xff09; 三、MySQL數據庫 1.下載和安裝 2.配置環境變量 四、SQL 1.SQL通用語法 2.SQL分類 前言 從本期開始&#xff0c;我們開始學習數據庫的相關理論和實踐知識&#xff0c;從入門…

jupyter 用pyecharts進行數據分析

一、jupyter和pyecharts下載和打開 因為我是用的pycharm&#xff0c;所以我直接在pycharm項目終端中下載pip install jupyter,pip install pyecharts 在你下載的項目路徑中輸入jupyter notebook 之后會進入頁面 Jupyter 具體使用參考這個鏈接&#xff1a;Jupyter Notebook基本…

Pygame教程01:初識pygame游戲模塊

Pygame是一個用于創建基本的2D游戲和圖形應用程序。它提供了一套豐富的工具&#xff0c;讓開發者能夠輕松地創建游戲和其他圖形應用程序。Pygame 支持許多功能&#xff0c;包括圖像和聲音處理、事件處理、碰撞檢測、字體渲染等。 Pygame 是在 SDL&#xff08;Simple DirectMed…

常用設計模式詳解

設計模式 1.UML圖 統一建模語言是用來設計軟件的可視化建模語言。定義了用例圖、類圖、對象圖、狀態圖、活動圖、時序圖、協作圖、構件圖、部署圖等 9 種圖。 1.1類圖 1.1.1類的表示方式 在UML類圖中&#xff0c;類使用包含類名、屬性(field) 和方法(method) 且帶有分割線…

基本正則表達式

基本正則表達式 正則命令功能&#xff3e;尖角號&#xff0c;用于模式的最左側&#xff0c;如“^oldbpy"&#xff0c;匹配以oldboy單詞開頭的行$美元符&#xff0c;用于模式的最右側&#xff0c;如"oldboy$"&#xff0c;表示以oldboy單詞結尾的行^$組合符&…

Java基于springboot的廚藝交流平臺的設計與實現代碼

摘 要 使用舊方法對廚藝交流信息進行系統化管理已經不再讓人們信賴了&#xff0c;把現在的網絡信息技術運用在廚藝交流信息的管理上面可以解決許多信息管理上面的難題&#xff0c;比如處理數據時間很長&#xff0c;數據存在錯誤不能及時糾正等問題。 這次開發的廚藝交流平臺功…

如何優雅的刪除undo表空間

前言 因磁盤空間不足&#xff0c;需要將undo表空間遷移到其它的存儲空間 本文介紹如何優雅的刪除undo表空間&#xff0c;并在新的存儲空間中創建新的undo表空間 詳細操作步驟如下&#xff1a; 1、查看默認undo表空間 SQL>show parameter undo NAME …

Redis的主從搭建

1.準備兩臺機器&#xff0c;安裝好redis 2.修改從服務器的redis配置 slaveof <masterip> <masterport>兩個參數 masterip 主的ip 主的端口號 masterport 3. 啟動redis 1.先啟動主機redis 2.再啟用從機redis 主機redis日志打印 從機redis 日志打印

【python】1.python3.12.2和pycharm社區版的安裝指南

歡迎來CILMY23的博客喔&#xff0c;本篇為【python】1.python3.12.2和pycharm社區版的安裝指南&#xff0c;感謝觀看&#xff0c;支持的可以給個一鍵三連&#xff0c;點贊關注收藏。 目錄 一、python3.12.2的下載與安裝 1.1下載 1.2安裝 二、pycharm的安裝 2.1下載安裝 2…

Bootstrap的使用

目錄 js的引入&#xff1a; 1.行內式 2.嵌入式 3.外鏈式 Bootstrap:的引入 注意事項&#xff1a; 條件注釋語句&#xff1a; 柵格系統&#xff1a; 列嵌套&#xff1a; 列偏移&#xff1a; 列排序&#xff1a; 響應式工具&#xff1a; Bootstrap的字體圖標的使用&a…

2024最新算法:河馬優化算法(Hippopotamus optimization algorithm,HO)求解23個基準函數,提供MATLAB代碼

一、河馬優化算法 河馬優化算法&#xff08;Hippopotamus optimization algorithm&#xff0c;HO&#xff09;由Amiri等人于2024年提出&#xff0c;該算法模擬了河馬在河流或池塘中的位置更新、針對捕食者的防御策略以及規避方法。河馬優化算法的靈感來自河馬生活中觀察到的三…