摘要:簡化版自己實現(xiàn)與盡量不要用規(guī)則太復(fù)雜用只需要注意兩點所有對象也都是因為地址不一樣自己寫與用這是這是這是這是這是這是這是這是這是直接使用直接使用得到兄妹結(jié)點傳入的參數(shù)是一個節(jié)點返回兄妹結(jié)點的數(shù)組添加或刪除傳入的第一個參數(shù)是結(jié)點第
簡化版自己實現(xiàn)jQuery 1. == 與===
盡量不要用 == 規(guī)則太復(fù)雜
用===只需要注意兩點,1.NaN===NaN,false,2.所有對象===也都是false,因為地址不一樣.
jQuery-Study
01_myjQuery1.js
// 得到兄妹結(jié)點 //傳入的參數(shù)是一個節(jié)點,返回兄妹結(jié)點的數(shù)組 function getSiblings(node) { var allSilings = node.parentNode.children; var siblingsArray = {length:0}; for (let i = 0; i < allSilings.length; i++) { if (allSilings[i]!==node){ siblingsArray[siblingsArray.length] = allSilings[i]; siblingsArray.length++; } } return siblingsArray; } //添加或刪除class //傳入的第一個參數(shù)是結(jié)點,第二個參數(shù)是對象, 這個對象里是key:value,key就是要操作的class,value判斷操作類型,true添加,false刪除 function addClass(node,object){ for (let key in object){ //對象調(diào)用方法的兩種方式: // obj.f() // obj["f"]() var methodName; methodName = object[key] ? "add":"remove"; node.classList[methodName](key); /*上面兩句代碼相當(dāng)于 if (object[key]) { node.classList.add(key); }else { node.classList.remove(key); }*/ } } window.mydom = {}; mydom.getSiblings = getSiblings; mydom.addClass = addClass;//命名空間,常用的設(shè)計或者組合就叫做設(shè)計模式.哈希,數(shù)組,都是一種設(shè)計模式 //所以jQuery就是這樣來的,jQuery就是一個命名空間,里面有很多函數(shù). // 命名空間作用:1.方便識別庫,2.如果都放在window里,可能會覆蓋別的庫,所以命名空間是為了防止覆蓋別的函數(shù) window.onload = function () { // 測試 // 如何直接使用item3.addclass()?,item3.getSiblings()? // 方法一:給原型鏈加公有屬性公有方法,但是有缺點,容易覆蓋 Node.prototype.getSiblings = function () { var allSilings = this.parentNode.children;//誰調(diào)用這個函數(shù),this就是誰 var siblingsArray = {length:0}; for (let i = 0; i < allSilings.length; i++) { if (allSilings[i]!==this){ siblingsArray[siblingsArray.length] = allSilings[i]; siblingsArray.length++; } } return siblingsArray; } let item3 = document.getElementById("item3"); // console.log(item3.getSiblings.call(item3));如果用cal.第一個參數(shù)就是函數(shù)里的this,如果不用call(),那么this就自動變成了item3 console.log(" 方法一:"); console.log(item3.getSiblings());//測試成功 Node.prototype.addClass = function (object) { for (let key in object){ var methodName; methodName = object[key] ? "add":"remove"; this.classList[methodName](key); } } // item3.addClass.call(item3,{a:true,xxx:false,c:true});;如果用call.第一個參數(shù)就是函數(shù)里的this,如果不用call(),那么this就自動變成了item3 console.log(" 方法一:"); item3.addClass.call(item3,{a:true,xxx:false,c:true}); // item3.addClass({a:true,xxx:false,c:true}); console.log(item3);//測試成功 // 如何直接使用item3.addclass()?,item3.getSiblings()? // 方法二:因為方法一在原型中添加函數(shù)容易覆蓋,所以自己做一個類似的Node出來 var Node2 = function (node) {// 將要操作的結(jié)點傳進去,然后返回一個對象,這個對象里給添加了有操作這個節(jié)點方法,所以對象.方法就可以實現(xiàn)操作了,而不需要mydom.addclass(item3,...)這樣了 return{ getSiblings: function () { var allSilings = node.parentNode.children; var siblingsArray = {length:0}; for (let i = 0; i < allSilings.length; i++) { if (allSilings[i]!==node){ siblingsArray[siblingsArray.length] = allSilings[i]; siblingsArray.length++; } } return siblingsArray; }, addClass:function (object) { for (let key in object){ var methodName; methodName = object[key] ? "add":"remove"; node.classList[methodName](key); } } } } let item4 = document.getElementById("item4"); var item4obj = Node2(item4); console.log(" 方法二:"); console.log(item4obj.getSiblings());//測試成功 console.log(" 方法二:"); item4obj.addClass({a:true,xxx:false,c:true}); console.log(item4);//測試成功 // 改為jQuery var jQuery = function (nodeOrSelector) {//將Node2改為jQuery,jQuery可以根據(jù)選擇器去找到對應(yīng)的元素 var node; if(typeof nodeOrSelector==="string"){ node = document.querySelector(nodeOrSelector); }else { node = nodeOrSelector; } return{ getSiblings: function () { var allSilings = node.parentNode.children; var siblingsArray = {length:0}; for (let i = 0; i < allSilings.length; i++) { if (allSilings[i]!==node){ siblingsArray[siblingsArray.length] = allSilings[i]; siblingsArray.length++; } } return siblingsArray; }, addClass:function (object) { for (let key in object){ var methodName; methodName = object[key] ? "add":"remove"; node.classList[methodName](key); } } } } let item5 = document.getElementById("item5"); var $item5 = jQuery(item5); console.log(" 改為jQuery方法:"); console.log($item5.getSiblings()); console.log(" 改為jQuery方法:"); $item5.addClass({red:true,xxx:false,c:true}); console.log(item5);//測試成功 var child3 = jQuery("ul>li:nth-child(3)"); child3.addClass({blue:true}); // jQuery操作多個節(jié)點 var jQueryS = function (nodeOrSelector) { var node = {}; if (typeof nodeOrSelector ==="string"){ var temp = document.querySelectorAll(nodeOrSelector);//先用querySelectorAll獲取這個偽數(shù)組 for (let i = 0; i < temp.length; i++) { node[i] = temp[i]; } node.length = temp.length;//將偽數(shù)組凈化,凈化成只有0123值和length的偽數(shù)組 } else if(nodeOrSelector instanceof Node){// 如果是node,也將其轉(zhuǎn)化成偽數(shù)組 node[0] =nodeOrSelector; node.length = 1; } node.getSiblings = function () { }; node.addClass = function (classesArray) {//傳入class數(shù)組,給選擇的多個節(jié)點都加上數(shù)組中class classesArray.forEach(value=>{ for (let i = 0; i < node.length; i++) { node[i].classList.add(value); } }) } node.getTexts = function () { var texts=[]; for (let i = 0; i < node.length; i++) { texts.push(node[i].textContent); } return texts; } node.setTexts = function (text) { for (let i = 0; i < node.length; i++) { node[i].textContent = text; } } //set和get合并 node.text = function (text) { if (text===undefined){ var texts=[]; for (let i = 0; i < node.length; i++) { texts.push(node[i].textContent); } return texts; }else{ for (let i = 0; i < node.length; i++) { node[i].textContent = text; } } } return node; } var allNodes = jQueryS("ul>li:nth-child(even)");//偶數(shù)孩子 allNodes.addClass(["big","green"]); console.log(allNodes.getTexts()); console.log(allNodes.text()); // console.log(allNodes.text(1));//測試成功 //總結(jié):jQuery的作用就是將選擇其選擇的元素放到一個對象里,這個對象里有01234標(biāo)序,代表每一個選擇的元素,有l(wèi)ength代表所有元素加起來總共的長度,有各種方法,addclass,gettext等等.就是反悔了這樣一個hash };
UseJquery.js
var $nodes = $("ul>li:nth-child(even)");//注意$nodesjQuery聲明的變量前面要加一個$,防止混淆,因為jQuery聲明的變量只能用jQuery的api,不能用dom的api. console.log($nodes); x.onclick = function () { $nodes.toggleClass("pink");//toggle,開關(guān),切換 // console.log(1); } var colorArray = ["blue","yellow","red","pink","big"] var $nodes2 = $("#ol2>li"); $nodes2.addClass(function (index,currentClass) { return colorArray[index];//ol里面的每一個li加了"blue","yellow","red","pink","big"這幾個屬性 }) //https://www.jquery123.com/addClass/3.this 和 arguments
f.call(asThis, input1,input2)
其中 asThis 會被當(dāng)做 this,[input1,input2] 會被當(dāng)做 arguments
禁止使用 f(input1, input2),因為學(xué)會 .call 才能理解 this
this 和 arguments
function f(){ "use strict" console.log(this) console.log(arguments) return undefined } f.call(1,2,3) // this 為 1,arguments 為 [2,3]
this 的值到底是什么?一次說清楚---方應(yīng)杭
this定義:this是call的第一個參數(shù).
this定義:this是call的第一個參數(shù).
this定義:this是call的第一個參數(shù).
「每日一題」JS中的閉包是什么?---方應(yīng)杭
關(guān)于原型鏈:
「每日一題」什么是 JS原型鏈?---方應(yīng)杭
JavaScript 世界萬物誕生記
dom就是一個命名的空間,命名的所屬對象
函數(shù)庫:特定種類的API
jQueryMobil已經(jīng)過時,不要學(xué)
測試代碼
Document
結(jié)果如下:
就像Boolea,Array一樣,
他的原型就是jQuery.prototype
var myjQueryS = function(node){ var Node = {} Node.length = 0 if((typeof node)==="string"){ var nodearr = document.querySelectorAll(node) for (let index = 0; index < nodearr.length; index++) { let element = nodearr[index]; Node[index] = element Node.length++ } }else{ Node["0"] = node Node.length++ } Node.addClass = function(addclass){ for (let index = 0; index < Node.length; index++) { let element = Node[index] element.classList.add(addclass) } } Node.text = function(text){ if(text===undefined){ let textArr = [] for (let index = 0; index < Node.length; index++) { let element = Node[index] textArr.push(element.textContent) } return textArr }else{ for (let index = 0; index < Node.length; index++) { let element = Node[index] element.textContent = text } } } return Node } var $div = myjQueryS("div") console.log($div) $div.addClass("xxx") console.log($div.text()) // $div.text("xxx")
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/95317.html
摘要:全局的函數(shù)第個對象第個對象作為構(gòu)造器進行調(diào)用也就是利用運算符進行調(diào)用。與操作的共同使用只有通過操作產(chǎn)生的對象,可以使用構(gòu)造器函數(shù)原型鏈上的內(nèi)容,否則對象只能使用自己原型鏈上的內(nèi)容。 今天這個話題是因為這幾天看了《JavaScript忍者秘籍》,感覺這本書把這幾個內(nèi)容講的蠻透徹了,特撰本文,以便日后翻閱。(應(yīng)該都會以知識點的形式給出吧。) 函數(shù) 1.【基本類型】 JavaScript中函...
摘要:引言上一節(jié)介紹了高階函數(shù)的定義,并結(jié)合實例說明了使用高階函數(shù)和不使用高階函數(shù)的情況。我們期望函數(shù)輸出,但是實際上調(diào)用柯里化函數(shù)時,所以調(diào)用時就已經(jīng)執(zhí)行并輸出了,而不是理想中的返回閉包函數(shù),所以后續(xù)調(diào)用將會報錯。引言 上一節(jié)介紹了高階函數(shù)的定義,并結(jié)合實例說明了使用高階函數(shù)和不使用高階函數(shù)的情況。后面幾部分將結(jié)合實際應(yīng)用場景介紹高階函數(shù)的應(yīng)用,本節(jié)先來聊聊函數(shù)柯里化,通過介紹其定義、比較常見的...
摘要:語言缺陷是一門在極短時間里創(chuàng)造的腳本語言,它存在很多的不足,這使得在學(xué)習(xí)時無形加大了學(xué)習(xí)的難度,本文就將這些內(nèi)容進行總結(jié),以防繼續(xù)掉坑。 JS語言缺陷 js是一門在極短時間里創(chuàng)造的腳本語言,它存在很多的不足,這使得在學(xué)習(xí)時無形加大了學(xué)習(xí)的難度,本文就將這些內(nèi)容進行總結(jié),以防繼續(xù)掉坑。 1.變量提升 1.1 案例分析 先來說一下變量提升,它其實就是先用后聲明,經(jīng)常被拿來說明的一個例子是:...
摘要:高階函數(shù)不是的所特有的,其他編程語言也有。高階函數(shù)面向切面編程面向切面編程這種思想在開發(fā)中比較常見,主要就是將一些與核心業(yè)務(wù)無關(guān)的功能抽離出來,比如異常處理,日志統(tǒng)計等。 javascript的函數(shù)式語言特性 我們知道JavaScript使一門面向?qū)ο蟮木幊陶Z言,但這門語言同時擁有很多函數(shù)式語言的特性。 JavaScript的設(shè)計者在設(shè)計最初就參考了LISP方言之一的Scheme,引入...
摘要:后續(xù)說完上面的再對比下面的理解,會更深入的理解原型與原型鏈這里是對象擁有了這樣的方法,而不是,是繼承區(qū)別于方法直接作用于原型上例子的實現(xiàn) 所謂重載,就是一組相同的函數(shù)名,有不同個數(shù)的參數(shù),在使用時調(diào)用一個函數(shù)名,傳入不同參數(shù),根據(jù)你的參數(shù)個數(shù),來決定使用不同的函數(shù)!但是我們知道js中是沒有重載的,因為后定義的函數(shù)會覆蓋前面的同名函數(shù),但是我們又想實現(xiàn)函數(shù)重載該怎么辦呢? 第1種方法: ...
閱讀 1533·2021-11-23 09:51
閱讀 3646·2021-09-26 09:46
閱讀 2135·2021-09-22 10:02
閱讀 1849·2019-08-30 15:56
閱讀 3333·2019-08-30 12:51
閱讀 2235·2019-08-30 11:12
閱讀 2069·2019-08-29 13:23
閱讀 2331·2019-08-29 13:16