搜尋
首頁系統教程LinuxJavaScript物件導向輕鬆入門之綜合

JavaScript物件導向輕鬆入門之綜合

Mar 14, 2024 pm 03:22 PM
linuxlinux教程紅帽linux系統資料存取linux指令linux認證紅帽linuxlinux視頻

JavaScript物件導向輕鬆入門之綜合

需求:

#幾乎所有的web應用程式都需要將資料保存一些到本地,那麼我們就來做一個資料儲存器吧。

詳細需求:

#當本地儲存有數據時,取用本地的數據,沒有時使用預設的數據
判斷本地的資料是否過時,如果過時則不使用
預設使用localStorage,但支援使用其它儲存方式,並且要支援多方儲存,多方讀取

抽象化物件

#根據需求裡面的關鍵字,我們抽像出三個物件:資料存取、資料、儲存器
資料儲存管理器負責管理數據,對外暴露介面
資料對象負責對資料的操作
儲存器負責保持數據,讀取數據

儲存器物件

#DataStorageManagerBase揭露兩個介面save()和load(),模擬抽象類,告訴子類別一定要實作這兩個方法。
下面的範例用LocalStorage實作了一個子類,當然你也可以用cookie或其它方式實作。
為什麼要把LocalStorage這些儲存器進行二次封裝呢?直接用不就可以了嗎?
因為各種儲存器等api都是不一樣等,我們二次封裝後可以確保無論什麼儲存器對外暴露的介面都是save()和load()。

/*模拟数据储存器抽象类,其实这个类不要也可以*/
class DataStorageManagerBase {
    static getIns() {
        /* 储存器在整个应用的生命周期里应该只有一个实例 */
        if (!this._ins) this._ins = new this();
        return this._ins;
    }
    constructor() {
        this.name = null;
    }
    save(name/* string */, data/* any */) {
        throw '"' + this.constructor.name + "'类没有save()方法";
    }
    load(name/* string */) {
        throw '"' + this.constructor.name + "'类没有load()方法";
    }
}
class LocalStorageManager extends DataStorageManagerBase {
    static getIns() {
        /* 静态方法不能继承 */
        if (!this._ins) this._ins = new this();
        return this._ins;
    }
    constructor() {
        super();
        this.name = 'localStorage';
    }
    save(name/* string */, data/* any */) {
        console.log(name,data)
        if (!window.localStorage) return this;//判断这个储存器可用不可用,你也可以在这里抛出错误
        window.localStorage[name] = JSON.stringify(data);
        return this;
    }
    load(name/* string */) {
        //如果储存器不可用,返回false
        if (!window.localStorage) return false;
        //如果没有这个数据,返回false
        if (!window.localStorage[name]) return false;
        let dataLoaded = JSON.parse(window.localStorage[name]);
        return dataLoaded;
    }
}
資料物件

對資料的操作:保存、讀取、判斷版本等

class GlobalData {
    static addStorage(storage/* DataStorageManagerBase */) {
        /*动态添加储存器*/
        this._storages.push();
    }
    static getStorages() {
        return this._storages;
    }
    constructor(name, data, version) {
        this.name = name;
        this.data = data;
        this.version = version || 1;
        this._loadData();
        //初始化的该对象的时候,读取localStorage里的数据,看有没有已储存的数据,有就用该数据
    }
    getData() {
        return this._copy(this.data);
    }
    setData(data, notSave) {
        this.data = this._copy(data);
        if (!!notSave) return this;
        let dataToSave = {
            name: this.name,
            version: this.version,
            data: this.data
        };
        let storages = GlobalData.getStorages();
        for (let i = 0, l = storages.length; i 
<div style="font-size: 14pt; color: white; background-color: black; border-left: red 10px solid; padding-left: 14px; margin-bottom: 20px; margin-top: 20px;"><strong>資料存取物件</strong></div><p>#對資料物件管理,對外暴露三個介面getData(),setData(),config(),使用者透過這三個介面使用這個模組</p>
<pre class="brush:php;toolbar:false">class GlobalDataDao {
    static getIns() {
        if (!this._ins) this._ins = new this();
        return this._ins;
    }
    constructor() {
        this.GlobalDataClass = GlobalData;
        this._dataList = [];
    }
    getData(name/* string */) {
        let dataIns = this.getDataIns(name);
        if (!!dataIns) {
            return dataIns.getData();
        } else {
            return null;
        }
    }
    setData(name/* string */, data/* any */, notSave = false/* ?boolean */) {
        let dataIns = this.getDataIns(name);
        dataIns.setData(data, notSave);
        return this;
    }
    config(configs/* Array */) {
        /* 初始化数据
        interface Config {
            name: string;
            data; any;
            version?: number;
        }
        */
        for (let i in configs) {
            let de = configs[i];
            if (!!this.getDataIns(de.name)) {
                /* 如果数据名重复,抛出错误 */
                throw new Error('data name "' + de.name + '" is exist');
            };
            let dataIns = new GlobalData(de.name, de.data, de.version);
            this._dataList.push(dataIns);
        }
        return this;
    }
    getDataIns(name/* string */) {
        for (let i in this._dataList) {
            if (this._dataList[i].name === name) {
                return this._dataList[i];
            }
        }
        return false;
    }
}
使用
/*用法*/
let globalDataManeger = GlobalDataDao.getIns();

let configs = [
    {
        name: 'languageUsing',
        version: 1,
        data: {
            name: '简体中文',
            value: 'zh-cn'
        }
    }, {
        name: 'userPreference',
        version: 1,
        data: {
            theme: 'blue',
            menu: 'side_bar'
        }
    }
];
globalDataManeger.config(configs);
console.log(globalDataManeger);
let languageUsing = globalDataManeger.getData('languageUsing');
console.log(languageUsing);
languageUsing.name = 'English';
languageUsing.value = 'en';
globalDataManeger.setData('languageUsing', languageUsing);

以上是JavaScript物件導向輕鬆入門之綜合的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:Linux就该这么学。如有侵權,請聯絡admin@php.cn刪除
倉庫:用於輕鬆處理Flatpak應用的GUI倉庫:用於輕鬆處理Flatpak應用的GUIMay 09, 2025 am 11:30 AM

用於輕鬆Flatpak管理的GUI:介紹倉庫 僅使用命令行管理越來越多的FlatPak應用程序集合可能會很麻煩。 輸入倉庫,這是一種用戶友好的圖形接口,旨在簡化flatpak a

8個強大的Linux命令來識別硬盤驅動器瓶頸8個強大的Linux命令來識別硬盤驅動器瓶頸May 09, 2025 am 11:03 AM

本文為識別和解決Linux系統中的硬盤驅動器瓶頸提供了綜合指南。 經驗豐富的服務器管理員會發現這特別有用。緩慢的磁盤操作會嚴重影響應用程序性能,

Linux用戶的4個最佳QR碼生成器Linux用戶的4個最佳QR碼生成器May 09, 2025 am 10:27 AM

Linux系統下的高效二維碼生成工具 在當今數字世界中,二維碼已成為快速便捷地共享信息的一種方式,從URL、文本、聯繫人、Wi-Fi憑證,甚至支付信息,二維碼都簡化了數據訪問。 Linux用戶可以使用多種工具高效地創建二維碼。讓我們來看看一些可在Linux系統上直接使用的流行二維碼生成器。 QRencode QRencode是一個輕量級的命令行工具,用於在Linux上生成二維碼,它以其簡單性和效率而廣受好評,深受偏愛直接方法的Linux用戶的歡迎。 使用QRencode,您可以為URL、

基本操作系統8:用於MACOS和Windows的用戶友好型Linux基本操作系統8:用於MACOS和Windows的用戶友好型LinuxMay 09, 2025 am 10:19 AM

基本操作系統8 Circe:一種流暢,時尚的Linux體驗 基於Ubuntu的Linux發行版,Elementary OS已從簡單的主題包演變為一個完整的獨立操作系統。 以其用戶友好的界面而聞名

每個機器學習工程師的40個Linux命令每個機器學習工程師的40個Linux命令May 09, 2025 am 10:06 AM

掌握Linux對於任何機器學習(ML)工程師至關重要。 它的命令行界面提供了無與倫比的靈活性和控制,簡化工作流程並提高了生產力。本文概述了必需的Linux命令,FO解釋說

Arch Linux備忘單:初學者的基本命令Arch Linux備忘單:初學者的基本命令May 09, 2025 am 09:54 AM

Arch Linux:初學者的命令行備忘單 Arch Linux提供了無與倫比的控制,但對於新移民來說可能會令人生畏。該備忘單提供了自信管理系統的必要命令。 系統信息和更新 這些com

如何在Linux上安裝用於機器學習的Scikit-Learn如何在Linux上安裝用於機器學習的Scikit-LearnMay 09, 2025 am 09:53 AM

本指南提供了在Linux Systems上安裝和使用Scikit-Learn機器學習庫的全面演練。 Scikit-Learn(Sklearn)是一個功能強大的開源python庫,為各種機器提供多種工具L

如何在Ubuntu中安裝Kali Linux工具如何在Ubuntu中安裝Kali Linux工具May 09, 2025 am 09:46 AM

本指南說明瞭如何利用Docker訪問Kali Linux工具,這是Katoolin等過時方法的更安全,更有效的替代方案。 Katoolin不再積極維護,可能會在現代系統上引起兼容性問題。做

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。