如何用原生js封裝一個(gè)屬于自己的插件

今天介紹一下怎么寫屬于自己的插件,建議看之前溫習(xí)一下面向?qū)ο螅?br> 我就寫個(gè)簡(jiǎn)單的重置樣式的插件,話不多說先上代碼;

//SetStyles.js
(function(win, doc) {
    var defaultSettings = {
        color: "red",
        background: "blue",
        border: "2px solid #000",
        fontSize:"30px",
        textAlign:"center",
        width:"200px",
        borderRadius:"5px"
    };

    function SetStyles(options) {
        var self = this;
        //沒傳配置項(xiàng)自己丟錯(cuò)
        if(!options) {
            throw new Error("請(qǐng)傳入配置參數(shù)");
        }
        self = Object.assign(self, defaultSettings, options);
        
        self.container = doc.querySelector(self.container) || doc.querySelectorAll(self.container);
        self._changeStyles();
    }

    SetStyles.prototype = {
        _changeStyles: function() {
            var self = this;
            for(var pro in self) {
                if(pro == "container") {
                    continue;
                }
                if(pro == 'text' && typeof self[pro]== 'string') {
                    self.container.innerText = self[pro];
                    continue;
                }else if(pro == 'text' && typeof self[pro]== 'function'){
                    self.container.innerText = self[pro]();
                    continue;
                }
                self.container.style[pro] = self[pro];
            }
        }
    }
    win.SetStyles = SetStyles;
})(window, document)
    //調(diào)用
    var a = new SetStyles({
            container:"#test",
            background:"#fff",
            textAlign:"center",
            text:function(){
                return "我是文本";
            }
        });
    //text參數(shù)格式字符串或者函數(shù)
    //container用的querySelectAll方法,參數(shù)一致
    //其他css參數(shù)為字符串

我的這份代碼應(yīng)該足夠簡(jiǎn)單,看不懂的說明基礎(chǔ)還不夠哦,自己敲一敲,有問題的地方,自己console.log一下吧。
首先定義下一默認(rèn)的參數(shù)defaultSettings
然后寫個(gè)構(gòu)造函數(shù),里面為什么要用Object.assign合并對(duì)象,因?yàn)槟J(rèn)配置里有的你不一定全都寫,不寫的就默認(rèn)為默認(rèn)參數(shù),有的就選擇你寫的參數(shù),所以options放在后面;
最后把方法寫在原型里。
方法一般寫在原型里,屬性寫在構(gòu)造函數(shù)里。
大家應(yīng)該都能看的懂這段代碼的功能,重置css樣式,和jquery的css()函數(shù)類似。
但是不推薦大家用這個(gè),畢竟遵循原則,盡量少用js去操作dom,畢竟這種代價(jià)是很昂貴的,我寫這個(gè)只是為了讓大家了解一下如何封裝插件,要去更改css樣式,不如多寫幾個(gè)類,要用那種樣式,換個(gè)類名就行。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 作為一個(gè)前端er,如果不會(huì)寫一個(gè)小插件,都不好意思說自己是混前端界的。寫還不能依賴jquery之類的工具庫,否則裝...
    綽號(hào)陸拾柒閱讀 46,483評(píng)論 42 261
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,828評(píng)論 25 709
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 14,104評(píng)論 1 92
  • 文/sherry 我出生在一個(gè)內(nèi)地貧困縣,這里,我從小接受的教育就是學(xué)習(xí)改變命運(yùn)。那時(shí)候的我也不知道為什么要改變命...
    劉小云愛自由閱讀 346評(píng)論 1 1
  • 一滴荷露涼 一盞明前香 一朝一夕琴一張 一段舞袖揚(yáng) 一襲柔風(fēng)裳 一枕瓦上霜 一詩一畫墨一方 一念慕宋唐
    五月慕晴閱讀 258評(píng)論 3 3

友情鏈接更多精彩內(nèi)容