1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時(shí)間:8:30-17:00
      你可能遇到了下面的問題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      JS設(shè)計(jì)模式之單例模式(一)

      命名空間

      創(chuàng)新互聯(lián)長期為上千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為克井企業(yè)提供專業(yè)的成都網(wǎng)站制作、成都做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設(shè)克井網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

      單例模式是JavaScript中最常見的一種模式,通過這種模式可以為我們提供一個(gè)命名空間,例如jQuery庫的命名空間為jQuery或$。命名空間的使用是為了讓代碼更加整潔,在多人協(xié)作開發(fā)的情況下,不同的人定義的變量很有可能重復(fù),此時(shí)就需要使用命名空間來約束每個(gè)人定義的變量,使相同名稱的變量放在不同的命名空間中,避免相互干擾。例如:

      // A程序員的命名空間
      var A = {
        get: function(id){
          return document.getElementById(id);
        }
        css: function(id,key,value){
          get(id).style[key] = value;
        }
      }
      // B程序員的命名空間
      var B = {
        get: function(className){
          return document.getElementByClassName(className)[0];
        }
        css: function(className,key,value){
          get(className).style[key] = value;
        }
      }
      

      A、B兩個(gè)命名空間中都有一個(gè)get方法和一個(gè)css方法,用于元素獲取和元素樣式修改,不同的是A是通過id來獲取元素,而B是通過class來獲取元素,通過命名空間,可以使這些相同名稱的方法共存,使用時(shí)指定相應(yīng)的命名空間即可。

      模塊化

      JavaScript中單例模式除了定義命名空間之外,還可用于管理代碼庫的各個(gè)功能模塊。例如:

      google.dom.addClass       // 添加元素類
      google.dom.append        // 插入元素
      google.event.stopPropagation  // 阻止事件冒泡
      google.event.preventDefault   // 阻止默認(rèn)行為
      google.string.trim       // 去除字符串首尾空格
      google.string.encodeHTML    // 將字符串進(jìn)行HTML編碼
      

      以上各個(gè)模塊都位于google命名空間下,每個(gè)模塊都有屬于自己的方法,使用時(shí)只需按照需求調(diào)用特定功能模塊下對應(yīng)的方法即可。

      常量

      JavaScript中并沒有final、static這類關(guān)鍵字用來定義常量,但JavaScript非常靈活,通過常量只能訪問不能修改這一特點(diǎn),我們可以將變量保存在函數(shù)內(nèi)部,并且只提供獲取變量的方法,不提供設(shè)置變量的方法,通過閉包的方式使函數(shù)執(zhí)行一次并返回相應(yīng)的訪問方法對象,最后將這個(gè)對象放在全局空間中作為常量單例對象使用。例如:

      var Color = (function(){
        // 私有變量
        var color = {
          'RED': '#ff0000',
          'YELLOW': '#ffff00',
          'BLUE': '#0000ff'
        }
        // 返回訪問方法對象
        return {
          // 常量獲取方法
          get: function(name){
            return color[name] ? color[name] : null;
          }
        }
      })();
      
      var color = Color.get('BLUE');
      console.log(color);  // #0000ff
      
      

      以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


      名稱欄目:JS設(shè)計(jì)模式之單例模式(一)
      文章位置:http://ef60e0e.cn/article/gecici.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        马尔康县| 横山县| 沅陵县| 安溪县| 盖州市| 丰顺县| 砀山县| 长海县| 上林县| 望都县| 德昌县| 永康市| 遂平县| 长春市| 临澧县| 九龙城区| 荔浦县| 礼泉县| 贵南县| 安国市| 隆化县| 叶城县| 武夷山市| 神农架林区| 康保县| 台州市| 阿巴嘎旗| 叶城县| 武宁县| 红安县| 祥云县| 尼勒克县| 福海县| 武宁县| 南召县| 临沭县| 铜鼓县| 凤山县| 天台县| 长垣县| 虞城县|