jQuery學習筆記之JavaScript腳本庫和元素選擇器研究[圖]

jQuery學習筆記之JavaScript腳本庫和元素選擇器研究[圖]
jQuery是一套JavaScript腳本庫,至關於Java的類庫,將一些工具方法或者對象方法封裝在類庫中,方便用戶使用。
工廠函數指的是這些內建函數都是類對象,當你調用他們時,實際就是建立了一個類實例。
一.jQuery基本選擇器包括:ID選擇器,元素選擇器,類名選擇器,多種匹配條件選擇器,通配符選擇器。
1.ID選擇器(#id)
jQuery中的id選擇器至關於JavaScript中的document.getElementById()方法;
JavaScript只能調用DOM方法,jQuery能夠調用DOM方法,也能夠調用jQuery封裝的方法。
頁面中若是出現了兩個相同的id的屬性值,程序運行時會報出JS運行錯誤的對話框,因此要保證id屬性值惟一。
2.元素選擇器(element)
元素選擇器是根據元素名稱匹配相應的元素,元素選擇器匹配的是一組元素。它是jQuery包裝集,是一組Object對象,須要使用索引器來獲取單獨的文本信息。
eq()和 get(),默認都是從0開始計數
eq()方法返回的是一個jQuery包裝集,因此只能調用jQuery方法
get()方法返回的是一個DOM對象,因此調用DOM對象的方法
3.類名選擇器(.class)
類名選擇器是經過元素擁有的CSS類的名稱查找匹配的DOM元素html

jQuery學習筆記之JavaScript腳本庫和元素選擇器研究[圖]
4.複合選擇器(select1,select2,select3,selectN)
複合選擇器將多個選擇器組合在一塊兒,用逗號分隔開,只要符合任何一個篩選條件就會匹配,返回的是一個jQuery包裝集,利用索引器能夠獲取集合中的對象。
5.通配符選擇器(*)
二.層級選擇器
層級選擇器就是根據頁面上的DOM元素之間父子關係做爲匹配的篩選條件。
jQuery提供的層級選擇器的有:
1.ancestor descendan選擇器
用於給定的祖先元素下匹配的全部後代元素
2.parent  > child選擇器
該選擇器只能選擇父元素下直接的子元素
3.prev+next選擇器
用於匹配全部緊接在prev後面的next元素,pre與next是兩個相同的元素
4.prev~sibling選擇器
用於匹配prev以後的全部sibling元素,其中prev和sibling是兩個同輩元素
三.過濾選擇器
過濾選擇器包括
1.簡單過濾器
以冒號開頭,一般實現簡單過濾效果的過濾器
2.內容過濾器
經過DOM元素包含的文本內容以及是否含有匹配的元素進行篩選
:contains(text)匹配包含給定文本的元素
:empty匹配不包含子元素或者文本的元素
:has(selector)匹配含有選擇器匹配元素的元素
:parent匹配含有子元素或者文本的元素
3.可見性過濾器
可見性過濾器就是利用元素的可見狀態匹配元素,所以,可見性過濾器也有兩種,一種是匹配全部可見元素的:visible過濾器,另外一種是匹配不可見元素的:hidden過濾器
在應用:hidden過濾器的時候,display屬性是none以及input元素的type屬性爲:hidden的元素都會被匹配到
4.表單對象的屬性過濾器
表單對象的過濾器是經過表單元素的狀態屬性匹配元素,包括:
1.checked過濾器:匹配全部被選中的元素
2.disabled過濾器:匹配全部不可用的元素
3.enabled過濾器:匹配全部可用的元素
4.selected過濾器:匹配全部選中的option元素
5.子元素選擇器
子元素選擇器就是篩選給定某個元素的子元素,具體過濾條件由選擇器的種類而定
:first-child匹配全部給定元素的第一個元素
:last-child匹配全部給定元素的最後一個元素
:only匹配元素中惟一的子元素
:nth-child匹配父元素下的第N個子或奇偶元素,index從1開始,而不是從0開始
四.屬性選擇器
屬性選擇器就是經過元素的屬性做爲過濾條件進行篩選
五.表單選擇器
表單選擇器就是匹配常常在表單中出現的元素,可是匹配的元素不必定在表單中。
jQuery方法:
val():獲取文本框的值
ready():當頁面元素載入完成時就自動執行程序,自動爲按鈕綁定單擊事件
html():設置元素的文本內容
addClass():爲元素添加CSS類
removeClass():移除元素的CSS類
java同步容器類的問題,vector等:
你們都知道java中的同步容器類是線程安全的,可是在某些狀況下可能須要額外的客戶端加鎖來保護複合操做。容器上的常見的複合操做是:穆斯林的葬禮讀書筆記(http://www.simayi.net/dushubiji/895.html)心得感悟,迭代(遍歷完容器中的全部容器),跳轉(根據指定順序找到當前元素的下一個個元素)以及條件運算 。最多見的例如」若沒有則添加「(檢查map中是否存在key值,不存在再添加)。
在同步容器類中,這些複合操做在沒有客戶端加鎖的狀況下仍然是線程安全的,但當其餘線程併發地修改容器時,他們可能出現意料以外的行爲。
例如如下vector的getLast和setLast操做。雖然你們都知道vector是線程安全的,可是在VectorDemo中getLast不是線程安全的,由於list.size()和list,get()這兩個對list的操做不能保證他們倆的原子性,list.size()的結果在執行list.get()時可能已經發生狀態了(被其餘線程對list的remove所破壞)。讓其變成線程安全的辦法就是註釋裏的內容,就是鎖住list。java

相關文章
相關標籤/搜索