摘要:記錄看源碼時(shí)候不太了解的知識(shí)點(diǎn)關(guān)于新的選擇器之前只了解和,這個(gè)方法是匹配是否符合選擇器,返回值是但是大多不支持,需要用到瀏覽器前綴,有個(gè)不常用的運(yùn)算符按位非運(yùn)算符感覺是不實(shí)用的方法如果操作數(shù)能夠轉(zhuǎn)換為數(shù)值就直接取反并且減去一都轉(zhuǎn)化為數(shù)字
記錄看源碼時(shí)候不太了解的知識(shí)點(diǎn)
matchesSelector = element.matches ||element.webkitMatchesSelector ||element.mozMatchesSelector ||element.oMatchesSelector ||element.matchesSelector
關(guān)于H5新的選擇器api之前只了解querySeletor和querySeletorAll,MatchesSelector這個(gè)方法是匹配是否符合選擇器,返回值是true false;但是大多不支持,需要用到瀏覽器前綴,
let s = document.querySeletor("div").matchesSeletor(".theOne"); console.log(s); //true;
match = ~zepto.qsa(parent, selector).indexOf(element)
有個(gè)不常用的運(yùn)算符按位非運(yùn)算符~
感覺是不實(shí)用的方法
let num = 23, boo = false, obj = {}, arr = [], na = NaN, str = "abcdefg"; ~num //-24,如果操作數(shù)能夠轉(zhuǎn)換為數(shù)值就直接取反并且減去一; ~obj //-1,{}.[],undefined,null,false,NaN,“”都轉(zhuǎn)化為數(shù)字0在取反 ~str //-1對(duì)無(wú)法轉(zhuǎn)為數(shù)值的字符串等,轉(zhuǎn)為0 //~的運(yùn)算等級(jí)比.[]()優(yōu)先級(jí)低
運(yùn)算符優(yōu)先級(jí)別大概的邏輯是
取值>一元操作符(包含非運(yùn)算符!)>算術(shù)運(yùn)算>大小比較>相等不相等>邏輯與或>賦值>三元>逗號(hào)
function isPlainObject(obj) { return isObject(obj) && !isWindow(obj) && Object.getPrototypeOf(obj) == Object.prototype }
undefined和null的區(qū)別
undefined == null //如果str == null那么str會(huì)有兩個(gè)值成立
typeof null === "object"
typeof undefined === "undefined"
判斷是否是類似的數(shù)組對(duì)象,即有Length屬性
function likeArray(obj) { var length = !!obj && "length" in obj && obj.length, //綜合判斷obj是否存在,有l(wèi)ength屬性z如果都成立的話,最后取得Length的數(shù)值 type = $.type(obj) //判斷obj的類型 return "function" != type && !isWindow(obj) && (//是否是function ,window,array "array" == type || length === 0 || (typeof length == "number" && length > 0 && (length - 1) in obj) ) }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/89822.html
摘要:源碼結(jié)構(gòu)整體結(jié)構(gòu)如果在編輯器中將的源碼折疊起來(lái),看到的就跟上面的代碼一樣。參考源碼分析代碼結(jié)構(gòu)對(duì)象思想與源碼分析設(shè)計(jì)和源碼分析源碼中關(guān)于的問(wèn)題最后,所有文章都會(huì)同步發(fā)送到微信公眾號(hào)上,歡迎關(guān)注歡迎提意見 雖然最近工作中沒(méi)有怎么用 zepto ,但是據(jù)說(shuō) zepto 的源碼比較簡(jiǎn)單,而且網(wǎng)上的資料也比較多,所以我就挑了 zepto 下手,希望能為以后閱讀其他框架的源碼打下基礎(chǔ)吧。 源碼版...
摘要:所有瀏覽器瀏覽器不支持安卓中中有屬性安卓中中有屬性有屬性的有屬性的所以在不需要的瀏覽器會(huì)直接掉,不會(huì)執(zhí)行下面的所有代碼。見源碼行,可以看出在響應(yīng)無(wú)操作后,則觸發(fā)。 其實(shí)一直就想花些時(shí)間讀一讀那些優(yōu)秀的開源庫(kù),今天終于下了決定打算死磕下自己,2016年每個(gè)月讀2-3個(gè)優(yōu)秀的開源庫(kù),把源碼精彩的地方和自己心得分享給大家。 目錄 (一)背景(二)源碼解析(三)Zepto 點(diǎn)擊穿透與 Fast...
摘要:本文記錄,對(duì)的一些封裝庫(kù)的知識(shí),我希望從本文開始去深入學(xué)習(xí)這門語(yǔ)言,以及在面向?qū)ο螅蜕戏庋b的使用。讓自己在方面有能夠有一定進(jìn)步。 本文記錄jQuery,Zepto對(duì)js的一些封裝庫(kù)的知識(shí),我希望從本文開始去深入學(xué)習(xí)js這門語(yǔ)言,以及在面向?qū)ο螅蜕戏庋b的使用。讓自己在js方面有能夠有一定進(jìn)步。共勉 jQuery庫(kù) 簡(jiǎn)單的jQuery庫(kù)的實(shí)現(xiàn) 需要先了解閉包,立即執(zhí)行函數(shù)以及Jav...
摘要:形如源代碼在的原型上添加了相關(guān)方法。類似源代碼每個(gè)表單的和都通過(guò)編碼最后通過(guò)符號(hào)分割有了的基礎(chǔ),就是將相應(yīng)的和都通過(guò)編碼,然后用符號(hào)進(jìn)行分割,也就達(dá)到了我們要的結(jié)果。 前言 JavaScript最初的一個(gè)應(yīng)用場(chǎng)景就是分擔(dān)服務(wù)器處理表單的責(zé)任,打破處處依賴服務(wù)器的局面,這篇文章主要介紹zepto中form模塊關(guān)于表單處理的幾個(gè)方法,serialize、serializeArray、sub...
閱讀 2336·2021-10-11 10:59
閱讀 2616·2021-10-11 10:58
閱讀 3323·2021-09-08 09:35
閱讀 3832·2021-09-02 15:21
閱讀 1477·2019-08-30 15:53
閱讀 2626·2019-08-29 14:16
閱讀 2084·2019-08-26 14:00
閱讀 2970·2019-08-26 13:52