首頁 web前端 js教程 js面向對象編程

js面向對象編程

Jun 04, 2020 pm 12:30 PM
js 物件導向程式設計

一、物件導向程式設計

#1.程式導向與物件導向

    1)以過程為導向:專注於如何解決一個問題的過程步驟,程式設計特點是由一個個函數去實現每一步的過程步驟,沒有類別和物件的概念。

    2)物件導向:專注於由哪一個物件來解決問題,程式設計特點是出現一個類別,從類別中拿到對象,由這個物件去解決特定問題。

    對於呼叫者來說,以過程為導向需要呼叫者自己去實作各種函數。而面向對象,只需要呼叫者了解對像中具體方法的功能,不需要了解方法中的實作細節。

2.物件導向的三大特徵


      物件導向的三大特徵繼承、封裝、多型。 JS可以模擬實現繼承和封裝,但是無法模擬實現多態,所以JS是一門基於物件的語言,          而非傳統意義上的物件導向的語言。
3.類別與物件的關係


#    1)類別是抽象的,物件是特定的(類是物件的抽象化,物件是類別的具體化)

    2)類別是抽象的概念,只能說類別有屬性和方法,但是不能給屬性賦具體的。例如,人類有姓名,但是不能說人類的姓名叫什麼。 二、Javascript物件的創

建置方法

1.var obj = {}//簡單對象plainObject 物件字面量/物件直接量

2.建構子(特點:大駝峰式命名規則)

1)系統自帶的建構子

    var obj = new Object();//相當於var object = {}

2)自訂函數封裝

    // 函數在裡面加參數才能讓函數自訂,可隨意改變函數中對應參數的數據,生產物件的時候必須得new物件

function Car(color){
        this.color=color;
        this.name = "BMW";
        this.height = "1400";
        this.lang = "4900";
        this.weight = 1000;
        this.health = 100;
        this.run = function(){
            this.health -- ;
        }
    }
登入後複製

    var car = new Car("red");

3.物件建構函數的內部原理3步驟

    1)在函數體最上方隱式的加上一個物件:var this = {}

    2)執行函數體內的內容

    3)隱含的返回this物件

    

三、包裝類別

1.原始值是無法有屬性與方法(undefined、null、 number、boolean、string)

2.有些原始值經過包裝類別之後,可以進行呼叫   

        var num=123;//不是物件

        var num1=new Number(123);//是物件

3.隱含包裝類別的過程如下

  var num = 4;
  num.len = 3;//隐式发生转换,新建一个数字对象,然后添加属性并赋值,最后删除这个对象,所以在执行过程中没有报错
  console.log(num.len);//再新建一个数字对象,添加属性,所以最后输出为undefined
        
  var str="abcd";
  str.length=2;
  console.log(str.length);
  //输出为4,在输出时原始值str包装类之后输出的为new String('abcd').length,字符串自带length属性,所以输出长度为4
登入後複製

    推薦教學:###《JS教學》######

以上是js面向對象編程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟 股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟 Dec 17, 2023 pm 06:55 PM

股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟,需要具體程式碼範例隨著網路和科技的快速發展,股票交易已成為許多投資者的重要途徑之一。而股票分析是投資人決策的重要一環,其中蠟燭圖被廣泛應用於技術分析。學習如何使用PHP和JS繪製蠟燭圖將為投資者提供更多直觀的信息,幫助他們更好地做出決策。蠟燭圖是一種以蠟燭形狀來展示股票價格的技術圖表。它展示了股票價格的

PHP MVC 架構:建立面向未來的 Web 應用程式 PHP MVC 架構:建立面向未來的 Web 應用程式 Mar 03, 2024 am 09:01 AM

引言在當今快速發展的數位世界中,建立健壯、靈活且可維護的WEB應用程式至關重要。 PHPmvc架構提供了實現這一目標的理想解決方案。 MVC(模型-視圖-控制器)是一種廣泛使用的設計模式,可將應用程式的各個方面分離為獨立的元件。 MVC架構的基礎MVC架構的核心原理是分離關注點:模型:封裝應用程式的資料和業務邏輯。視圖:負責呈現資料並處理使用者互動。控制器:協調模型和視圖之間的交互,管理使用者請求和業務邏輯。 PHPMVC架構phpMVC架構遵循傳統MVC模式,但也引進了語言特定的功能。以下是PHPMVC

PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 Dec 18, 2023 pm 03:39 PM

隨著網路金融的快速發展,股票投資已經成為了越來越多人的選擇。而在股票交易中,蠟燭圖是常用的技術分析方法,它能夠顯示股票價格的變動趨勢,幫助投資人做出更精準的決策。本文將透過介紹PHP和JS的開發技巧,帶領讀者了解如何繪製股票蠟燭圖,並提供具體的程式碼範例。一、了解股票蠟燭圖在介紹如何繪製股票蠟燭圖之前,我們首先需要先了解什麼是蠟燭圖。蠟燭圖是由日本人

js和vue的關係 js和vue的關係 Mar 11, 2024 pm 05:21 PM

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

'PHP 物件導向程式設計模式:理解 SOLID 原則及其應用” 'PHP 物件導向程式設計模式:理解 SOLID 原則及其應用” Feb 25, 2024 pm 09:20 PM

SOLID原則是物件導向程式設計模式中的一組指導原則,旨在提高軟體設計的品質和可維護性。由羅伯特·馬丁(RobertC.Martin)提出,SOLID原則包括:單一職責原則(SingleResponsibilityPrinciple,SRP):一個類別應該只負責一項任務,並且這個任務應該被封裝在類別中。這樣可以提高類別的可維護性和可重複使用性。 classUser{private$id;private$name;private$email;publicfunction__construct($id,$nam

PHP擴充開發:如何設計自訂函數以支援物件導向程式設計? PHP擴充開發:如何設計自訂函數以支援物件導向程式設計? Jun 01, 2024 pm 03:40 PM

PHP擴充功能可以支援物件導向編程,透過設計自訂函數來建立物件、存取屬性和呼叫方法。首先建立自訂函數實例化對象,然後定義取得屬性和呼叫方法的函數。在實戰中,我們可以自訂函數來建立一個MyClass對象,取得其my_property屬性,並呼叫其my_method方法。

golang函數在物件導向程式設計中高並發場景下的應用 golang函數在物件導向程式設計中高並發場景下的應用 Apr 30, 2024 pm 01:33 PM

在物件導向編程的高並發場景中,函數在Go語言中具有廣泛應用:函數作為方法:函數可附加到結構體,實現物件導向編程,方便操作結構體資料和提供特定功能。函數作為並發執行體:函數可作為goroutine的執行體,實現並發任務執行,提升程式效率。函數作為回調:函數可作為參數傳遞給其他函數,在特定事件或操作發生時被調用,提供靈活的回調機制。

See all articles