通過一個輪播圖插件來瞭解構造函數

来源:https://www.cnblogs.com/this-day/archive/2018/05/12/9024912.html
-Advertisement-
Play Games

例子:https://github.com/wayaha/rotateChart 在ES5中,構造函數的使用可以說是很能體現面向對象的編程思想,有學過c的同學,可以很明顯體會到面向過程和麵向對象的區別,不多瞎扯,這次通過一個輪播圖的插件來理解一下構造函數; 1、關於對象的創建方式 常見的創建對象方式 ...


例子:https://github.com/wayaha/rotateChart

在ES5中,構造函數的使用可以說是很能體現面向對象的編程思想,有學過c的同學,可以很明顯體會到面向過程和麵向對象的區別,不多瞎扯,這次通過一個輪播圖的插件來理解一下構造函數;


 

1、關於對象的創建方式

  常見的創建對象方式有:字面量和通過new + 構造函數的方式;

  字面量的方式相對靈活、簡單;缺點也很明顯,用一個需要造一個,不便於復用和屬性的繼承如下;

var person = {
    name: 'Picker',
    age: 18 ,
    doSomething: function (){
        console.log('I`m a developer, I can write code.');
     }
}

 

  

  另外通過new的方式創建,常用的獲取時間通過new Date();當然自己可以定義構造函數,如下,這樣可以創建一群這樣的人。

function Person (name, age) {
    this.name = name;
    this.age = age;
};
Person.prototype.doSomething =function (){
    console.log('I`m a developer, I can write code.');
};
var me = new Person('Picker',18)

 

  用起來方便,但是在new的時候構造函數內部也做了一堆的操作:

var me={};
me.__proto__ = Person.prototype;
Person.call(me);
return me;

  a、創建一個對象;

  b、把空對象的原型對象指向構造函數的原型對象,此時空對象可以訪問構造函數原型鏈上的方法和屬性,這個很關鍵;

  c、通過call方法改變構造函數的this指向,並執行構造函數,此時的對象擁有了構造函數的屬性和方法;

  d、返回對象me,即我們new出來的實例,構造函數預設有隱式返回,當構造函數有return時候,視情況而定,如果返回值是基礎類型,構造函數忽略它的存在,繼續返回預設值,如果是對象的形式,會返回該對象,代替生成的實例。

2、構造函數的創建

  a、構造函數預設使用大駝峰命名,首字母大寫;

  b、構造函數的初始化,可以通過上面例子的方式,也可以是通過Object.defineProperty();

 

function Person( name){
    Object.defineProperty(this, "name"{
        get :function(){
           return name;
        },
         set:function (newName){
          name =newName;
        },
        enumerable :true,
         configurable:true //可配置
       });
 }  
var me=new Person('Picker');

 

  c、在構造函數中使用原型對象;

    doSomething方法就是原型對象的方法;如果需要掛載到原型上的對象更多,可以使用字面量的方式,如:

Person.prototype ={
      sayName :function(){
          console.log(this.name);
      },
    doSomething =function (){
        console.log('I`m a developer, I can write code.');
    };
 }

    使用字面量形式改寫了原型對象改變了構造函數的屬性,因此他指向Object而不是Person。這是因為原型對象具有一個constructor屬性。當一個函數被創建時,它的prototype屬性也被創建,且該原型對象的constructor屬性指向該構造函數。當使用對象字面量形式改寫原型對象時,其constructor屬性將被置為對象Object.為了避免這一點,需要在改寫原型對象的時候手動重置constructor,如下:

Person.prototype ={
      constructor = Person,
      sayName :function(){
          console.log(this.name);
      },
    doSomething =function (){
       console.log('I`m a developer, I can write code.');
    };
 }

  d、另外,在構造函數中this指向問題

    箭頭函數是不能用來創建構造函數的;

    構造函數中定義方法使用 function() {},不要使用箭頭函數,箭頭函數中的this會指向window,而不是構造函數或者實例;

    構造函數中關於事件綁定的函數,需要改變函數的this指向構造函數或者實例,如果需要的話;

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 個人寫這個彈出框的原因就一個,就是能給我帶來可復用,追求新,要簡單,可擴展。要達到炫酷有點難度,分析後還是決定以功能為主,因為是用jq和animation實現的彈出框組件,所以看起來難度不大,簡稱co-dialog。 演示效果DEMO 靈感來源,因為工作中用到dialog,發現UI設計的彈出框的風格 ...
  • 之前一個已經工作的同學問我上傳圖片立即顯示怎麼實現,這個問題雖然不難,但我還是要去打開電腦找到項目,點開一個個目錄;這時候博客的作用就顯露出來了。。 話不多說,進入正題: 先看看效果 只需要在js中添加如下代碼就可以實現了 這段代碼主要是讀取你選中的圖片文件,先生成圖片,然後再把生成的文件以base ...
  • 知識點 1.小程式裡面,點擊頁面頂部的返回按鈕的時候,返回的那個頁面不會刷新。頁面直接跳轉返回都可以傳參跳轉。需要做處理的時候,在onshow的時候接收參數並處理即可。 2.<!--?xml version="1.0" encoding="UTF-8"?--> 頁面有彈層時,阻止下麵的頁面滾動。 這 ...
  • 初入ES6隨筆 var c = a => console.log(a) let a1 = 1; //只在塊兒狀作用域生效的變數聲明 const a2 = 1; //常量聲明,值不可改變,快兒狀作用域 解構賦值語法 let [a3, b3, c3] = [1, 2, 3]; //數組解構賦值 let ...
  • <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8"> <title></title> <link rel="stylesheet" href="../css/reset.css"/> <link rel="stylesheet" h ...
  • <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8"> <title></title> <link rel="stylesheet" href="../css/reset.css"/> <link rel="stylesheet" h ...
  • 一、盒子模型 標準盒子模型(W3C盒子) 標準盒子模型(W3C盒子) 不論是標準盒模型還是IE盒子模型,都有content、padding、border、margin四個部分組成,但從上圖也可以看出W3C盒子和IE盒子主要區別在與content寬度上的區別 w3c中的盒子模型的寬:包括margin+ ...
  • 前面的話 iphone4發佈是幾年前的事情,而如今早已是移動互聯網的時代。人們不再正襟危坐在電腦前,而更願意把時間耗費在手機上,隨時隨地地享受互聯網。在移動端可以使用最新最炫的前端技術,而不用再考慮老版本IE的相容性。當前,很多公司的前端開發都是移動優先,因此,移動端開發已經成為前端開發工程師的標配 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...