詳解JS與Jquery獲得的對象的區別與聯繫

来源:https://www.cnblogs.com/gamecc666/archive/2019/08/12/11337552.html
-Advertisement-
Play Games

世上無難事只怕有心人,敲代碼也一樣只要你用心去搞懂一件事,即使一個小小的用法對你以後也會有很大的作用; 項目雖然趕得緊但是有些問題百度找完答案解決之後,也要自己梳理一遍做到心領神會!!!今天就直接來上周遇到的情況: 就是使用JS中的類似:documnet.getelementbyid('')方法與$ ...


世上無難事只怕有心人,敲代碼也一樣只要你用心去搞懂一件事,即使一個小小的用法對你以後也會有很大的作用;

項目雖然趕得緊但是有些問題百度找完答案解決之後,也要自己梳理一遍做到心領神會!!!今天就直接來上周遇到的情況:

就是使用JS中的類似:documnet.getelementbyid('')方法與$('xxx')獲得對象的區別於怎麼進行兩者之間的轉換;

現在開始直奔今天主題:兩者對象的區別(以下數據通過打日誌的方法就可以獲得 typeof() 即可)

   Jquery得到的對象類型:$('xxx')===================得到的類型是:[object Object]

      Js得到的對象的類型:docunment.getelementbyid('')==得到的類型是:[object HTMLDivElement]

KeyNote:

   a: 什麼是Jquery對象?

       答:通過jQuery包裝DOM對象後產生的對象。jQuery對象是jQuery獨有的 != Js中的對象,只能可以使用jQuery里的方法。

Jquery中的對象既然是對JS中對象的包裝,那麼一定會有轉換的方法;看了網上很多例子基本上是千篇一律,不過有一點還是很慶幸的,

那就是例子通俗易懂,那麼下麵就直接開始上菜了o(∩_∩)o 

   前提:如果一個獲取的是jQuery對 象,那麼我們在變數前面加上$,如:var $variab = jQuery對象;

              如果獲取的是DOM對象,則與習慣普通一樣:var variab = DOM對象;這麼約定只是便於講解與區別,實際使用中並不規定。 

   轉換方法:

             a : jQuery對象轉成DOM對象;

                  兩種轉換方式將一個jQuery對象轉換成DOM對象:[index]和.get(index); 
                        (1)jQuery對象是一個數據對象,可以通過[index]的方法,來得到相應的DOM對象。 
                             如:var $v =$("#v") ; //jQuery對象 
                                     var v=$v[0]; //DOM對象 
                                     alert(v.checked) //檢測這個checkbox是否被選中 
                        (2)jQuery本身提供,通過.get(index)方法,得到相應的DOM對象 
                             如:var $v=$("#v"); //jQuery對象 
                                    var v=$v.get(0); //DOM對象 
                                    alert(v.checked) //檢測這個checkbox是否被選中 

             b :  DOM對象轉成jQuery對象: 
                   
對於已經是一個DOM對象,只需要用$()把DOM對象包裝起來,就可以獲得一個jQuery對象了。$(DOM對象) 
                  如:var v=document.getElementById("v"); //DOM對象 
                         var $v=$(v); //jQuery對象 
                         轉換後,就可以任意使用jQuery的方法了。 
        通過以上方法,可以任意的相互轉換jQuery對象和DOM對象。需要再強調註意的是:DOM對象才能使用DOM中的方法,jQuery對象是不可以用DOM中的方法。  

    Eg : 

        下麵是其它的相關使用方法:
           1、DOM對象轉jQuery對象 
                普通的Dom對象一般可以通過$()轉換成jQuery對象。 

                如:$(document.getElementById("msg")) 
                返回的就是jQuery對象,可以使用jQuery的方法。 

           2、jQuery對象轉DOM對象 
                由於jQuery對象本身是一個集合。所以如果jQuery對象要轉換為Dom對象則必須取出其中的某一項,一般可通過索引取出。 
                如: $("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5] 

               這些都是Dom對象,可以使用Dom中的方法,但不能再使用jQuery的方法。 

               以下幾種寫法都是正確的: 
                   $("#msg").html(); 
                   $("#msg")[0].innerHTML; 
                   $("#msg").eq(0)[0].innerHTML; 
                   $("#msg").get(0).innerHTML;

           3、兩種方法獲取對象方式: 如有 <form name="formName"  id="formid"></form>

                通過id:

                document.getElementById('formid');

                $('#formid')

                通過name

                document.getElementsByName('formName')[0]

                $("form[name='formName']")

 

Jquery自帶的方法列表如下:

 

 

  版權聲明:本文為博主原創文章,如需轉載,請標明出處。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在上一篇中,我們談到過 要提升電腦的性能,可以從上面這三方面著手。 通過指令數/CPI,好像都太難了。 因此工程師們,就在CPU上多放晶體管,不斷提升CPU的時鐘頻率,讓CPU更快,程式的執行時間就會縮短。 從1978年Intel發佈的8086 CPU開始,電腦的主頻從5MHz開始,不斷攀升 1 ...
  • UNPIVOT特點 UNPIVOT運算符通過將列旋轉到行來執行PIVOT的反向操作,UNPIVOT 並不完全是 PIVOT 的逆操作。 PIVOT 執行聚合,並將多個可能的行合併為輸出中的一行。UNPIVOT 不重現原始表值表達式的結果,因為行已被合併。 另外,UNPIVOT 輸入中的 NULL 值 ...
  • 學過大數據的人都應該知道kafka、RabbitMQ這些分散式消息訂閱系統,本文今天著重講解下kakfa。kafka有非常好的橫向擴展性,可實時存儲海量數據,是流數據處理中間件的事實標準。本文將介紹Kafka是如何保證數據可靠性和一致性的。 數據可靠性 kafka作為一個商業級消息中間件,消息的可靠 ...
  • MySQL是現在普遍使用的資料庫,但是如果宕機了必然會造成數據丟失。為了保證MySQL資料庫的可靠性,就要會一些提高可靠性的技術。MySQL主從複製可以做到實時熱備數據。本文介紹MySQL主從複製原理及其配置過程。 術語:主從複製——master slave replication(M-S模式)。 ...
  • 一臺ORACLE實例(Oracle Database 10g Release 10.2.0.5.0)啟動時,報“Error 942 occured during Initialization of Bufq KUPC$S_1_20181023155636”錯誤,具體情況如下所示,內容信息來自告警日誌... ...
  • 平時每個開發者都會討論數據量大時,sql的優化問題。但是並不是每個人都會有100w的數據量可以用來實戰,那麼今天我們就自己動手,模擬一個100w數據量的表。 創建原理 其實創建的方法有很多,有快的也有慢的。本博客中寫的當然不是最快的那個,但確實是比較好操作和理解的。那麼我先來說明一下它的原理:它是利 ...
  • 一、安裝與刪除 安裝 sudo apt-get update #更新源 sudo apt-get install mysql-server #安裝mysql 刪除 sudo apt-get autoremove mysql-\* --purge (彈出提示框,是否刪除數據(刪除後數據就沒了,註意備份 ...
  • 版權聲明:本文為xing_star原創文章,轉載請註明出處! 本文同步自http://javaexception.com/archives/186 FloatingActionButton 動態更換背景色 最近碰到了個需求場景,需要動態切換FloatingActionButton的背景色 先看下xm ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...