$ 是 JQuery 常用的一個回傳函數,定義為 "選取" 英文是 selector 的縮寫
10年的長島網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。全網整合營銷推廣的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整長島建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。創新互聯從事“長島網站設計”,“長島網站推廣”以來,每個客戶項目都認真落實執行。
例子︰
$.function();
就是 選取 JQuery 定義的 function() 執行
$('input')
就是 選取 HTML 當中全部的 input 標簽
$('#abc')
就是 選取 HTML 當中 ID 名稱為 abc 的物件
$.fn.testing = function() {}
就是 選取 JQuery 內核函數 fn (函數) 回傳給 testing 這個名稱、定義為一個功能 function()
這個符號的來歷是
CSS3
選擇器,jquery支持CSS3選擇器。
$("div[id^='index']")
意思是:
id=index******
所有id為index開頭的div元素,比如
評論
5
加載更多
var
reg
=
/^\d{1,3}$/
;
這個東西是正則表達式,表示匹配一位到三位的0-9組成的數字
使用兩個'/'框起來的就是js的正則表達式。
/^\d{1,3}$/
其中'^'表示匹配字符串的開頭,'$'美元符表示字符串的結束
\d表示匹配0到9的所有數字
{x,y}表示之前的重復x到y次
所以這個
/^\d{1,3}$/
的意思就是說匹配1到3位的數字
if((heightVal!=''
!reg.test(heightVal))
||
heightVal300){
!reg.test(heightVal)這個表示的就是heightVal這個變量不符合前面的正則的格式。
jQuery是現在最流行的Javascript框架, $是其中最常見的符號,已經在jQuery留下了深深的烙印。 接下來我會徹底分析這個符號背后隱藏的秘密。jQuery,高效,精煉,特別是對DOM元素對象操作的簡化,很大程度上將前端程序員從一大堆冗余的代碼解放出來,大大提高了開發效率!對多瀏覽器的兼容性,也最大限度讓程序員擺脫各種bug的糾纏$符號作為元素選擇器的簡寫,最早是由Prototype庫使用,來簡寫getElementById,jQuery沿襲這一理念,并發揚光大,使$符號成為了jQuery最別具一格的特點。那么在jQuery中,$符號到底是啥?熟悉jQuery的人應該知道,幾乎jQuery所有操作,都是從$符號開始,當作為元素選擇器的時候,操作結果返回的是一個jQuery對象。 那么,現在就看jQuery類的構造函數的主要代碼jQuery對象的構造函數 var jQuery = (function() { //創建jQuery對象,給所有的jQuery方法提供統一的入口,避免繁瑣難記 var jQuery = function( selector, context ) { //jQuery的構造對象,調用了jQuery.fn.init方法 //最后返回jQuery.fn.init的對象 return new jQuery.fn.init( selector, context, rootjQuery ); }, ..... //定義jQuery的原型,jQuery.fn指向jQuery.prototype對象 jQuery.fn = jQuery.prototype = { //重新指定構造函數屬性,因為默認指向jQuery.fn.init constructor: jQuery, init: function( selector, context, rootjQuery ) {.....}, ...... } ...... //返回jQuery變量,同時定義將全局變量window.jQuery和window.$指向jQuery return (window.jQuery = window.$ = jQuery); })(); 從以上jQuery的主體結構,我們可以看出,當首次執行完畢后,全局變量$和jQuery,都是指向了var jQuery=function(selector,context){}這個函數,這里,就可以下個結論,$就是jQuery的別名,實際調用jQuery.fn.init。再看看var jQuery=function(selector,context){}這個構造函數,為什么里面不直接返回jQuery的對象?而是調用另外一個方法呢?假如直接返回對象的話,每次使用jQuery對象,都要new jQuery() 這樣的話,十分不方便,直接將new 這個操作封裝在jQuery構造函數里面,簡化了實例化的操作,同時,jQuery通過了jQuery或者$符號,統一了接口,方便代碼的編寫,化繁為簡,提高效率。那么jQuery類具體是如何構造的?居然能支持各種參數形式的調用 直接上jQuery.fn.init的“轅馬”,jQuery的真實構造器,我們就可以完全清楚了init源碼 /*所有查找或生成元素的結果,封裝為jQuery對象數組返回. */ init: function( selector, context, rootjQuery ) { var match, elem, ret, doc; // 1)處理 $(""), $(null), or $(undefined) //this指向jQuery對象 if ( !selector ) { return this; } // 2)處理 $(DOMElement) //selector.nodeType得知為DOM元素,如果是DOM元素直接放進jQuery對象數組中 if ( selector.nodeType ) { this.context = this[0] = selector; this.length = 1; return this; } //3)body元素只出現一次, 優化查找 if ( selector === "body" !context document.body ) { this.context = document; this[0] = document.body; this.selector = "body"; this.length = 1; return this; } //4)如果是字符串,有六種情況, /* *(1)單個html元素 不帶屬性對象字面量 :createElement + merge *(2)單個html元素 帶屬性對象字面量 :createElement + attr + merge *(3)多個html元素 :buildFragment + merge *(4)#id 不帶context :getElementById或者getElementById + Sizzle *(5)#id 帶context :Sizzle *(6)experession string :Sizzle *(7)標簽選擇器 :Sizzle(內置getElementByTagName) */ if ( typeof selector === "string" ) { // 判斷是否為HTML string 還是 ID //如果是HTML strings match[1] 非空 //如果是ID strings match[1] 空 //quickExpr = /^(? jQuery.clone(ret.fragment) : ret.fragment).childNodes; } //將生成結果selector 合并到jQuery對象中 return jQuery.merge( this, selector ); // 處理$("#id"),例如$("#xxx"); } else { elem = document.getElementById( match[2] ); if ( elem elem.parentNode ) { //處理IE和Opera ID 與 Name 混淆的bug,使用Sizzle查找 if ( elem.id !== match[2] ) { return rootjQuery.find( selector ); } // 否則,簡單插入jQuery對象數組 this.length = 1; this[0] = elem; } this.context = document; this.selector = selector; return this; } // 處理 $(expr, $(...)),使用Sizzle查找,例如$("div"),$('div a'),$('div,a'),$('div:first') } else if ( !context || context.jquery ) { return (context || rootjQuery).find( selector ); // 處理: $(expr, context),例如$('div a');或者$('a','div')或者$('div').find('a'); } else { return this.constructor( context ).find( selector ); } //5)處理: $(function),設置DOM載的時候綁定的函數,等同于$().ready(){foo} } else if ( jQuery.isFunction( selector ) ) { return rootjQuery.ready( selector ); } //6)處理:$($(...)),完成克隆jQuery對象的簡單參數,具體由makeArray完成 if (selector.selector !== undefined) 完成加{ this.selector = selector.selector; this.context = selector.context; } //使用makeArray,為jQuery對象添加元素,例如$([1,2]); return jQuery.makeArray( selector, this ); }, 從源碼可以看出,jQuery 通過各種條件判斷和強大的正則表達式,實現了各種參數的調用。
$是jquery中最強大最重要的一個函數名。主要有以下幾個功能,也是jquery的核心功能。
1 選擇器 例如 $("p"),$("#test"),$("button")
2 特效 。例如 $("p").hide(),$("p").show()
3 ajax 。例如 $.get("ajax.php")
我是逍遙小天地,期待你的交流
在jquery中,$是jquery的別名,所有使用$的地方也都可以使用jquery來替換,如$('#msg')等同于jquery('#msg')的寫法。然而,當我們引入多個js庫后,在另外一個js庫中也定義了$符號的話,那么我們在使用$符號時就發生了沖突。
可以為jquery重定義別名。如下:
var
$j=jquery.noconflict();
$j('#msg').hide();//此處$j就代表jquery
分享文章:jquery符號,jQuery語法
文章來源:http://vcdvsql.cn/article28/dsdgdjp.html
成都網站建設公司_創新互聯,為您提供做網站、關鍵詞優化、網站排名、App開發、網頁設計公司、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯