jQuery中的美元符號「$」的作用:1、作為jQuery包裝器,利用選擇器來選擇DOM元素;2、作為幾個通用的實用工具函數的命名空間的前綴;3、建立DOM元素;4、擴充jQuery;5、解決「window.onload」函數的衝突。
本教學操作環境:windows7系統、jquery1.12.4版本、Dell G3電腦。
推薦教學:jq教學
1、選擇器
在CSS中選擇器的作用是選擇頁面中某一類別(類別選擇器)元素或某一個元素(ID選擇器)
#,而jQuery中的"$"作為選擇器,同樣是選擇某一類或某一類元素,只不過jQuery提供了
更多更全面的選擇方式。並且為使用者處理了瀏覽器的相容問題
h2 a{ /添加CSS属性/ }
而在jquery中則可以透過以下程式碼來選取c1a436a314ed609750bd7c7d319db4da標記下包含的所有子標記3499910bf9dac5ae3c52d5ede7383485,作為一個物件數組,供javascript使用
$("h2 a")
$(selector)
或
jQuery(selector)
其中selector符合CSS3標準
可以看到jQuery的表示方法簡潔很多
$("#showp“)
需要用for循環遍歷整個DOM
$(".SomeClass")
$("p : odd")
$("td:nth-child(1)")
$("li > a")
# ("a[href=pdf]")
注意:
在jQuery中美元符號"$"其實就等同於"jQuery",從jQuery的原始碼中可以看出
為了編寫程式碼的方便,通常都會採用"$"來取代"jQuery"
2、函數前綴
在javascript中,開發者經常要便攜一些小函數來處理各種操作細節,例如在使用者提交表單時,
需要將文字方塊中的最前端和最末端的空格清理掉,javascript沒有提供類似trim()的功能,而引入
jQuery後,便可以直接使用trim()函數,例如
$.trim(sString);
以上程式碼相當於:
jQuery.trim(sString);
即trim()函數時jQuery物件的一個方法。
3、解決window.onload函數的衝突
#由於頁面的HMTL框架需要在頁面完全載入之後才能使用,因此在DOM程式設計時window.onload函數
頻繁被使用。倘若頁面中有多處都需要使用該函數,或者其他.js檔案中也包含window.onload函數,
衝突問題十分棘手
jQuery中的ready()方法很好的解決了上述問題,它能夠自動將其中的函數在頁面載入完成後運行,
並且在同一個頁面中可以使用多個ready()方法,而且不互相衝突。例如
$(document).ready(function(){ $("table.datalist tr:nth-child(odd)").addClass("altrow"); });
對於上述程式碼jQuery也提供了簡寫,可以省略其中的"(document).ready"部分,程式碼如下:
$(function(){ $("table.datalist tr:nth-child(odd)").addClass("altrow"); });
4、建立DOM元素
利用DOM方法建立元素節點,通常需要將document.createElement()、document.create TextNode()、
appendChild()搭配使用,十分麻煩,而jQuery中使用"$"符號可以直接建立DOM元素。例如
var oNewP = $("e388a4556c0f65e1904146cc1a846bee這是個好故事5f557f62ae7ac7a14e0b1cb564790dfc")
以上程式碼等同於javascript中的如下程式碼:
var oNewP = document.createElement("p");// 新建节点 var oText = document.createTextNode("这是一个好故事"); oNewP.appendChild(oText);
另外,jQuery也提供了DOM元素的insertAfter()方法,偽程式碼如下:
$(function(){ // ready函数 var oNewP = $("<p>这是一个好故事</>");// 创建DOM元素 oNewP.insertAfter("#myTarget");// insertAfter()方法 }); <body> <p id="myTarget">插入到这行文字之后</p> <p>也就是插入到这行文字之前,但这行没有id,也可能不存在</p> </body>
5.自訂新增"$"
jQuery無法滿足所有使用者的所有需求,且有一些特殊的需求十分小眾,也不適合放到整個jQuery框架中,
使用者可以自訂該方法。程式碼如下:
$.fn.disable = function(){ return this.each(function(){ if(typeof this.disabled != "undefined") this.disabled = true; }); }
以上代码首先设置".fn.disable",表明为""添加一个方法“disable()”,其中“$.fn”是扩展jQuery时所必须的
然后利用匿名函数定义这个方法,即用each()将调用这个方法的每个元素的disabled属性均设置为true(如果该属性存在)
6、解决"$"的冲突
如果其他框架也是用了“",会引起冲突,jQuery同样提供了noConflict()方法来解决""冲突问题
jQuery.noConflict();
以上代码可以使""按照其他javascript框架的方式运算,这时再jQuery中便不能在使用“”,而必须使用jQuery,
例如$("p p") 必须写成jQuery("p p").
更多编程相关知识,请访问:编程入门!!
以上是jQuery中的美元符號$有什麼作用的詳細內容。更多資訊請關注PHP中文網其他相關文章!