摘要:面向?qū)ο缶幊堂嫦蜻^(guò)程是一門(mén)面向過(guò)程的語(yǔ)言,也就是側(cè)重點(diǎn)是實(shí)現(xiàn)一件事的步驟。面向?qū)ο笠允挛餅橹行?,?cè)重于完成某件事所需要的事物的特征和行為的設(shè)計(jì)。
面向?qū)ο缶幊?/b>
面向過(guò)程
javascript是一門(mén)面向過(guò)程的語(yǔ)言,也就是側(cè)重點(diǎn)是實(shí)現(xiàn)一件事的步驟。
特點(diǎn):有良好的可擴(kuò)展性和重用性,降低了代碼間的耦合度,接近日常思維。
面向?qū)ο?/pre>以事物為中心,側(cè)重于完成某件事所需要的事物的特征和行為的設(shè)計(jì)。
特點(diǎn):封裝、繼承、多態(tài),耦合度低,復(fù)用度好。
相信這些概念性的東西,網(wǎng)上真的是一搜一大堆,在我使用我的方法理解和上手面向?qū)ο笾?,容許我把概念性的東西寫(xiě)完,畢竟基礎(chǔ)特別重要啊。相信我,如果你正在閱讀,請(qǐng)忍耐一兩分鐘
相關(guān)名詞prototype : 獲取構(gòu)造函數(shù)的原型對(duì)象
constructor : 獲取原型對(duì)象的構(gòu)造函數(shù)
--proto-- : 獲取實(shí)例對(duì)象的構(gòu)造函數(shù)的原型對(duì)象
原型鏈 : 構(gòu)造函數(shù)自身會(huì)有原型對(duì)象,通過(guò)prototype查看,構(gòu)造函數(shù)的實(shí)例對(duì)象自身也會(huì)有原型對(duì)象,通過(guò)--proto--查看,--proto--是object類型,當(dāng)訪問(wèn)一個(gè)實(shí)例化的屬性時(shí),瀏覽器會(huì)先查找自身內(nèi)部屬性,沒(méi)有就找--proto--,直到--proto--類型為null。
New關(guān)鍵字作用:創(chuàng)建一個(gè)空對(duì)象,讓空對(duì)象調(diào)用構(gòu)造函數(shù)給自己賦值,將該對(duì)象返回
繼承實(shí)現(xiàn)B繼承A
方式一:在B的構(gòu)造函數(shù)內(nèi)部寫(xiě)A.call(this);缺點(diǎn):參數(shù)設(shè)置不靈活
方式二:(使用原型鏈實(shí)現(xiàn)繼承)step1:改變自身原型對(duì)象B.prototype=new A();step2:修復(fù)原型對(duì)象指向的構(gòu)造函數(shù)B.prototype.constructor=B
好啦,概念性的東西就寫(xiě)到這,下面開(kāi)始我的代碼之旅,現(xiàn)在已經(jīng)晚上11:30整,我好瞌睡啊,太困了,把這個(gè)寫(xiě)完我就去睡覺(jué)了Zzzz
基礎(chǔ)設(shè)置國(guó)際慣例,先把代碼的基礎(chǔ)設(shè)置好
div, p { width: 100px; height: 30px; border: 1px solid #ffffd; margin: 30px auto; } div.open,p.open{ background: pink; }1.基礎(chǔ)版/*NO.1 * 基礎(chǔ)方法 * 缺點(diǎn):代碼冗余,重復(fù)獲取元素重復(fù)循環(huán)操作 * 功能:修改背景色 */ var divs1 = document.getElementsByTagName("div"); var ps1 = document.getElementsByTagName("p"); for (var i = 0; i < divs1.length; i++) { divs1[i].style.backgroundColor = "pink"; } for (var i = 0; i < ps1.length; i++) { ps1[i].style.backgroundColor = "pink"; }2.進(jìn)階版(一)/*NO.2 * 進(jìn)階方法 * 缺點(diǎn):太局限,只能設(shè)置樣式 * 功能:修改背景色 */ function getDOM(tagName){ return document.getElementsByTagName(tagName); } function setStyle(arr,styleName,styleVal){ for (var i = 0; i < arr.length; i++) { arr[i].style[styleName] = styleVal; } } var divs2 = getDOM("div"); var ps2 = getDOM("p"); setStyle(divs2,"backgroundColor","#00a09d"); setStyle(ps2,"backgroundColor","#00a09d");3.進(jìn)階版(二)/*NO.3 * 進(jìn)階方法 * 缺點(diǎn):代碼不利于閱讀,沒(méi)有結(jié)構(gòu)化 * 功能:修改寬度,填充文字,遍歷封裝 */ function getDOM(tagName){ return document.getElementsByTagName(tagName); } function each(arr,callback){ for (var i = 0; i < arr.length; i++) { callback(arr[i]) } } var divs2 = getDOM("div"); var ps2 = getDOM("p"); each(divs2,function(tag){ tag.style.width = "200px"; tag.innerText = "I have a pen!!!"; })4.進(jìn)階版(三)/*NO.4 * 進(jìn)階方法,傳統(tǒng)面向?qū)ο髮?xiě)法(獨(dú)立作用域) * 功能:添加樣式,遍歷封裝 */ function Tool(bgColor){ this.bgColor = bgColor||"#00a09d"; this.getDom = function(tagName){ return document.getElementsByTagName(tagName); }; this.each = function(arr,callback){ for (var i = 0; i < arr.length; i++) { arr[i].style.backgroundColor = this.bgColor; callback(arr[i]); } }; } //實(shí)例化(使用) var tool = new Tool(); var ps3 = tool.getDom("p"); var divs3 = tool.getDom("div"); tool.each(divs3,function(tag){ tag.style.width = "200px"; tag.innerText = "I have a pen!!!"; })5.終極版/*NO.5 * 進(jìn)階方法,ES6面向?qū)ο髮?xiě)法(獨(dú)立作用域,類本身指向構(gòu)造函數(shù)) * 功能:將傳入的對(duì)象變成紅色,填充文字,添加點(diǎn)擊效果(歪樓了,需求改成這慫樣子了) * 說(shuō)明:實(shí)例化之后立即實(shí)現(xiàn)以上功能 * 功能:修改背景,填充文字,綁定事件...... */ class Tool{ //構(gòu)造函數(shù)(options為實(shí)例化傳入的參數(shù)) //作用:設(shè)置默認(rèn)參數(shù),合并默認(rèn)參數(shù)和傳入的參數(shù),實(shí)現(xiàn)繼承 constructor(options){ let dafultOpations = { element:"", bgColor:"red", color:"#fff" } this.options = Object.assign({},dafultOpations,options); //合并對(duì)象 assign(相同項(xiàng)會(huì)覆蓋) merge(相同項(xiàng)會(huì)合并) this.checkOptions().setStyle().setText().bindClick() //實(shí)例化后立即執(zhí)行這些方法,每個(gè)方法在調(diào)用完成后一定要釋放this } //由于該類的實(shí)現(xiàn)依賴于傳入的DOM,此方法用來(lái)確保已經(jīng)傳入DOM,若實(shí)例化沒(méi)有傳入,則拋出異常 checkOptions(){ if(!this.options.element){ throw new Error("Element is required!!!") } return this; } setStyle(){ for (var i = 0; i < this.options.element.length; i++) { this.options.element[i].style.backgroundColor = this.options.bgColor; this.options.element[i].style.textAlign = "center"; this.options.element[i].style.color = this.options.color; } return this; } setText(){ for (var i = 0; i < this.options.element.length; i++) { this.options.element[i].innerText = "呆呆Akuma"; } return this; } bindClick(){ for (var i = 0; i < this.options.element.length; i++) { let __this = this.options.element[i]; //需將當(dāng)前的元素區(qū)分開(kāi) __this!=this let flag = false; __this.addEventListener("click",()=>{ if(flag = !flag){ __this.style.backgroundColor = "pink" }else{ __this.style.backgroundColor = this.options.bgColor; } }) } return this; } } var divs = new Tool({ element:document.getElementsByTagName("div"), bgColor:"#00a09d" }); var ps = new Tool({ element:document.getElementsByTagName("p"), bgColor:"#f48" });目前看起來(lái),這個(gè)終極版好像是最繁瑣的,首先我要說(shuō)明,這里只是介紹面向?qū)ο缶幊淌窃趺椿厥?,?duì)于漫天飛的this真的神煩,不過(guò)多寫(xiě)寫(xiě)就好了,習(xí)慣就好,要學(xué)會(huì)控制它,如果你成功看完這篇文章,你就會(huì)發(fā)現(xiàn),隨著版本(暫時(shí)就算版本吧)升級(jí),功能也慢慢增多,靈活性更好,代碼的可擴(kuò)展性更高啦,至于質(zhì)疑一個(gè)簡(jiǎn)單的功能至于寫(xiě)這么復(fù)雜嗎?
很好,我覺(jué)得面向?qū)ο缶幊叹褪窃燧喿拥倪^(guò)程,輪子就相當(dāng)于工具。打個(gè)比方,伐樹(shù)你會(huì)選擇電鋸還是斧頭,劈柴你會(huì)選擇電鋸還是斧頭,相信答案就在你心里,好了不寫(xiě)了,真困了,快睡著了。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/93739.html
摘要:設(shè)計(jì)模式是以面向?qū)ο缶幊虨榛A(chǔ)的,的面向?qū)ο缶幊毯蛡鹘y(tǒng)的的面向?qū)ο缶幊逃行┎顒e,這讓我一開(kāi)始接觸的時(shí)候感到十分痛苦,但是這只能靠自己慢慢積累慢慢思考。想繼續(xù)了解設(shè)計(jì)模式必須要先搞懂面向?qū)ο缶幊?,否則只會(huì)讓你自己更痛苦。 JavaScript 中的構(gòu)造函數(shù) 學(xué)習(xí)總結(jié)。知識(shí)只有分享才有存在的意義。 是時(shí)候替換你的 for 循環(huán)大法了~ 《小分享》JavaScript中數(shù)組的那些迭代方法~ ...
摘要:在近期看到了函數(shù)式編程這本書(shū)預(yù)售的時(shí)候就定了下來(lái)。主要目的是個(gè)人目前還是不理解什么是函數(shù)式編程。且和現(xiàn)在在學(xué)習(xí)函數(shù)式編程有莫大的關(guān)系。加速大概了解了函數(shù)式編程之后??偨Y(jié)看完了第一章也是可以小結(jié)一下的函數(shù)式編程。 本文章記錄本人在學(xué)習(xí) 函數(shù)式 中理解到的一些東西,加深記憶和并且整理記錄下來(lái),方便之后的復(fù)習(xí)。 在近期看到了《JavaScript函數(shù)式編程》這本書(shū)預(yù)售的時(shí)候就定了下...
摘要:并嘗試用為什么你統(tǒng)計(jì)的方式是錯(cuò)的掘金翻譯自工程師的文章。正如你期望的,文中的前端開(kāi)發(fā)單一職責(zé)原則前端掘金單一職責(zé)原則又稱單一功能原則,面向?qū)ο笪鍌€(gè)基本原則之一。 單頁(yè)式應(yīng)用性能優(yōu)化 - 首屏數(shù)據(jù)漸進(jìn)式預(yù)加載 - 前端 - 掘金前言 針對(duì)首頁(yè)和部分頁(yè)面打開(kāi)速度慢的問(wèn)題,我們開(kāi)始對(duì)單頁(yè)式應(yīng)用性能進(jìn)行優(yōu)化。本文介紹其中一個(gè)方案:基于 HTTP Chunk 的首屏數(shù)據(jù)漸進(jìn)式預(yù)加載方案,該方案總...
摘要:裝飾器的使用符合了面向?qū)ο缶幊痰拈_(kāi)放封閉原則。三簡(jiǎn)單的裝飾器基于上面的函數(shù)執(zhí)行時(shí)間的需求,我們就手寫(xiě)一個(gè)簡(jiǎn)單的裝飾器進(jìn)行實(shí)現(xiàn)。函數(shù)體就是要實(shí)現(xiàn)裝飾器的內(nèi)容。類裝飾器的實(shí)現(xiàn)是調(diào)用了類里面的函數(shù)。類裝飾器的寫(xiě)法比我們裝飾器函數(shù)的寫(xiě)法更加簡(jiǎn)單。 目錄 前言 一、什么是裝飾器 二、為什么要用裝飾器 ...
摘要:構(gòu)造函數(shù)調(diào)用時(shí),需要給它傳一個(gè)回調(diào)函數(shù)。當(dāng)監(jiān)聽(tīng)的元素進(jìn)入可視區(qū)域或者從可視區(qū)域離開(kāi)時(shí),回調(diào)函數(shù)就會(huì)被調(diào)用。構(gòu)造函數(shù)的返回值是一個(gè)觀察器實(shí)例。它是一個(gè)數(shù)組,每個(gè)成員都是一個(gè)門(mén)檻值,默認(rèn)為,即交叉比例達(dá)到時(shí)觸發(fā)回調(diào)函數(shù)。 IntersectionObserve這個(gè)API,可能知道的人并不多(我也是最近才知道...),這個(gè)API可以很方便的監(jiān)聽(tīng)元素是否進(jìn)入了可視區(qū)域。 * { marg...
閱讀 2468·2021-11-19 09:40
閱讀 3601·2021-11-17 17:08
閱讀 3807·2021-09-10 10:50
閱讀 2229·2019-08-27 10:56
閱讀 1953·2019-08-27 10:55
閱讀 2649·2019-08-26 12:14
閱讀 1002·2019-08-26 11:58
閱讀 1501·2019-08-26 10:43