這篇文章主要介紹“JavaScript要封裝的原因是什么”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“JavaScript要封裝的原因是什么”文章能幫助大家解決問題。
創(chuàng)新互聯(lián)服務(wù)項目包括會昌網(wǎng)站建設(shè)、會昌網(wǎng)站制作、會昌網(wǎng)頁制作以及會昌網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,會昌網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到會昌省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
需要封裝的原因:1、通過封裝可以減少代碼的冗余,使代碼看起來不復(fù)雜,減少不必要的代碼;2、對象只用對外提供與其它對象交互的必要接口,可以對內(nèi)部數(shù)據(jù)提供不同級別的保護,以防止程序中無關(guān)部分意外的改變或錯誤使用了對象的私有部分,可提升安全性。
本教程操作環(huán)境:windows10系統(tǒng)、javascript1.8.5版、Dell G3電腦。
封裝是面向?qū)ο蟮娜齻€基本特征之一,將現(xiàn)實世界的事物抽象成計算機領(lǐng)域中的對象,對象同時具有屬性和行為(方法),這種抽象就是封裝.
大家在日常開發(fā)過程中,具有相同處理邏輯的代碼通常會進行函數(shù)的封裝來減少代碼的冗余,使代碼看起來更優(yōu)雅美觀,那么
當(dāng)多個實體對象他們擁有相同的一些屬性和行為(方法)時,自然也要把這些相同的屬性和行為抽象出來,減少不必要的代碼。
封裝的重要特性:數(shù)據(jù)隱藏。
對象只對外提供與其它對象交互的必要接口,而將自身的某些屬性和實現(xiàn)細(xì)節(jié)對外隱藏,通過這種方式,對象對內(nèi)部數(shù)據(jù)提供了不同級別的保護,以防止程序中無關(guān)的部分意外的改變或錯誤的使用了對象的私有部分。這樣就在確保正常交互的前提下,保證了安全性,不需要關(guān)心對象實現(xiàn)的方法即可使用這個對象。
函數(shù)(function)--最簡單的封裝
函數(shù)對任何語言來說都是一個核心的概念。通過函數(shù)可以封裝任意多條語句,而且可以在任何地方、任何時候調(diào)用執(zhí)行。
如何封裝: 將零散的的語句寫進函數(shù)的花括號內(nèi),成為函數(shù)體,然后就可以調(diào)用了。
未封裝代碼:
var body = document.getElementsByTagName("body")[0]; var h2 = document.createElement("h2"); body.style.backgroundColor = "green"; h2.innerText = "綠了"; body.appendChild(h2);
缺點:
易被同名變量覆蓋--因為在全局作用域下聲明的變量,容易被同名變量覆蓋
立即執(zhí)行--解析器讀取到此處立即執(zhí)行
封裝代碼:
function makeGreen() { var body = document.getElementsByTagName("body")[0]; var h2 = document.createElement("h2"); body.style.backgroundColor = "green"; h2.innerText = "綠了"; body.appendChild(h2); }
優(yōu)點:
避免了全局變量--因為存在函數(shù)作用域(函數(shù)作用域畫重點,以后要考)
按需執(zhí)行--解析器讀取到此處,函數(shù)并未執(zhí)行,只有當(dāng)你需要的時候,調(diào)用此函數(shù)即可
提高代碼重用性
關(guān)于“JavaScript要封裝的原因是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。