成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

初試面向?qū)ο缶幊?

cikenerd / 1028人閱讀

摘要:面向?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

相關(guān)文章

  • JS程序

    摘要:設(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ù)組的那些迭代方法~ ...

    melody_lql 評(píng)論0 收藏0
  • JS函數(shù)式編程讀書(shū)筆記 - 1

    摘要:在近期看到了函數(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í)候就定了下...

    G9YH 評(píng)論0 收藏0
  • 前端思考 - 收藏集 - 掘金

    摘要:并嘗試用為什么你統(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ù)加載方案,該方案總...

    LinkedME2016 評(píng)論0 收藏0
  • 【Python】一文弄懂python裝飾器(附源碼例子)

    摘要:裝飾器的使用符合了面向?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)單。 目錄 前言 一、什么是裝飾器 二、為什么要用裝飾器 ...

    liuchengxu 評(píng)論0 收藏0
  • IntersectionObserve初試

    摘要:構(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...

    LucasTwilight 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<