色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

鴻蒙TypeScript學習第17天:【對象】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-15 15:33 ? 次閱讀

1、TypeScript 對象

對象是包含一組鍵值對的實例。 值可以是標量、函數、數組、對象等,如下實例:

var object_name = { 
    key1: "value1", // 標量
    key2: "value",  
    key3: function() {
        // 函數
    }, 
    key4:["content1", "content2"] //集合
}復制

以上對象包含了標量,函數,集合(數組或元組)。

對象實例

鴻蒙開發文檔參考了:[qr23.cn/AKFP8k]

TypeScript

var sites = { 
   site1:"Runoob", 
   site2:"Google" 
}; 
// 訪問對象的值
console.log(sites.site1) 
console.log(sites.site2)復制

編譯以上代碼,得到以下 JavaScript 代碼:

JavaScript

var sites = { 
   site1:"Runoob", 
   site2:"Google" 
}; 
// 訪問對象的值
console.log(sites.site1) 
console.log(sites.site2)復制

輸出結果為:

Runoob
Google

2、TypeScript 類型模板

假如我們在 JavaScript 定義了一個對象:

var sites = { 
   site1:"Runoob", 
   site2:"Google" 
};復制

這時如果我們想在對象中添加方法,可以做以下修改:

sites.sayHello = function(){ return "hello";}

如果在 TypeScript 中使用以上方式則會出現編譯錯誤,因為Typescript 中的對象必須是特定類型的實例。

TypeScript

sites.sayHello = function(){ return "hello";}復制

編譯以上代碼,得到以下 JavaScript 代碼:

JavaScript

var sites = {
    site1: "Runoob",
    site2: "Google",
    sayHello: function () { } // 類型模板
};
sites.sayHello = function () {
    console.log("hello " + sites.site1);
};
sites.sayHello();復制

輸出結果為:

hello Runoob

此外對象也可以作為一個參數傳遞給函數,如下實例:

TypeScript

var sites = {
    site1: "Runoob",
    site2: "Google",
    sayHello: function () { } // 類型模板
};
sites.sayHello = function () {
    console.log("hello " + sites.site1);
};
sites.sayHello();復制

編譯以上代碼,得到以下 JavaScript 代碼:

JavaScript

var sites = {
    site1: "Runoob",
    site2: "Google"
};
var invokesites = function (obj) {
    console.log("site1 :" + obj.site1);
    console.log("site2 :" + obj.site2);
};
invokesites(sites);復制

輸出結果為:

site1 :Runoob
site2 :Google

3、鴨子類型(Duck Typing)

鴨子類型(英語:duck typing)是動態類型的一種風格,是多態(polymorphism)的一種形式。

在這種風格中,一個對象有效的語義,不是由繼承自特定的類或實現特定的接口,而是由"當前方法和屬性的集合"決定。

搜狗高速瀏覽器截圖20240326151547.png

"當看到一只鳥走起來像鴨子、游泳起來像鴨子、叫起來也像鴨子,那么這只鳥就可以被稱為鴨子。"

在鴨子類型中,關注點在于對象的行為能做什么,而不是關注對象所屬的類型。例如,在不使用鴨子類型的語言中,我們可以編寫一個函數,它接受一個類型為"鴨子"的對象,并調用它的"走"和"叫"方法。在使用鴨子類型的語言中,這樣的一個函數可以接受一個任意類型的對象,并調用它的"走"和"叫"方法。如果這些需要被調用的方法不存在,那么將引發一個運行時錯誤。任何擁有這樣的正確的"走"和"叫"方法的對象都可被函數接受的這種行為引出了以上表述,這種決定類型的方式因此得名。

interface IPoint { 
    x:number 
    y:number 
} 
function addPoints(p1:IPoint,p2:IPoint):IPoint { 
    var x = p1.x + p2.x 
    var y = p1.y + p2.y 
    return {x:x,y:y} 
} 
 
// 正確
var newPoint = addPoints({x:3,y:4},{x:5,y:1})  
 
// 錯誤 
var newPoint2 = addPoints({x:1},{x:4,y:3})

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙
    +關注

    關注

    59

    文章

    2543

    瀏覽量

    43840
  • HarmonyOS
    +關注

    關注

    80

    文章

    2085

    瀏覽量

    32345
  • OpenHarmony
    +關注

    關注

    28

    文章

    3840

    瀏覽量

    18259
收藏 0人收藏

    評論

    相關推薦
    熱點推薦

    鴻蒙TypeScript入門學習4:【TS變量聲明】

    變量是一種使用方便的占位符,用于引用計算機內存地址。 我們可以把變量看做存儲數據的容器。
    的頭像 發表于 03-29 14:49 ?1733次閱讀

    鴻蒙TypeScript入門學習6:【條件語句】

    條件語句用于基于不同的條件來執行不同的動作。 TypeScript 條件語句是通過一條或多條語句的執行結果(True 或 False)來決定執行的代碼塊。
    的頭像 發表于 04-01 13:51 ?988次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b>入門<b class='flag-5'>學習</b><b class='flag-5'>第</b>6<b class='flag-5'>天</b>:【條件語句】

    鴻蒙TypeScript學習7:【TypeScript 循環】

    有的時候,我們可能需要多次執行同一塊代碼。一般情況下,語句是按順序執行的:函數中的第一個語句先執行,接著是第二個語句,依此類推。 編程語言提供了更為復雜執行路徑的多種控制結構。
    的頭像 發表于 04-02 14:28 ?1092次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>7<b class='flag-5'>天</b>:【<b class='flag-5'>TypeScript</b> 循環】

    鴻蒙TypeScript 開發學習9:【TypeScript Number】

    TypeScript 與 JavaScript 類似,支持 Number 對象。 Number 對象是原始數值的包裝對象
    的頭像 發表于 04-07 18:02 ?1030次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b> 開發<b class='flag-5'>學習</b><b class='flag-5'>第</b>9<b class='flag-5'>天</b>:【<b class='flag-5'>TypeScript</b> Number】

    鴻蒙TypeScript入門學習11【Array(數組)】

    數組對象是使用單獨的變量名來存儲一系列的值。 數組非常常用。
    的頭像 發表于 04-09 14:38 ?1712次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b>入門<b class='flag-5'>學習</b><b class='flag-5'>第</b>11<b class='flag-5'>天</b>【Array(數組)】

    鴻蒙語言TypeScript學習16:【類】

    TypeScript 支持面向對象的所有特性,比如 類、接口等。
    的頭像 發表于 04-15 09:29 ?1310次閱讀
    <b class='flag-5'>鴻蒙</b>語言<b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>16<b class='flag-5'>天</b>:【類】

    鴻蒙TypeScript學習20:【模塊】

    TypeScript 模塊的設計理念是可以更換的組織代碼。 模塊是在其自身的作用域里執行,并不是在全局作用域,這意味著定義在模塊里面的變量、函數和類等在模塊外部是不可見的,除非明確地使用 export 導出它們。類似地,我們必須通過 import 導入其他模塊導出的變量、函數、類等。
    的頭像 發表于 04-18 15:19 ?1017次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>20<b class='flag-5'>天</b>:【模塊】

    【觸覺智能 Purple Pi OH 開發板體驗】二、鴻蒙系統APP應用例程學習HDC使用學習

    兩年開發鴻蒙APP也是使用的這兩種語言進行開發。當下看TypeScript程序還能說勉強看懂,但是當下開發程序就沒那個實力了,需要之后在抽時間學習。技術更新的也確實是快?。。?! 二、天氣預報程序開發
    發表于 08-31 11:13

    鴻蒙TypeScript入門學習2TypeScript安裝】

    本文介紹 TypeScript 環境的安裝。 我們需要使用到 npm 工具安裝,如果你還不了解 npm,可以參考我之前文檔。
    的頭像 發表于 03-27 15:22 ?748次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b>入門<b class='flag-5'>學習</b><b class='flag-5'>第</b>2<b class='flag-5'>天</b>【<b class='flag-5'>TypeScript</b>安裝】

    鴻蒙TypeScript開發入門學習3:【TS基礎類型】

    任意值是 TypeScript 針對編程時類型不明確的變量使用的一種數據類型,它常用于以下三種情況。
    的頭像 發表于 03-28 15:02 ?789次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b>開發入門<b class='flag-5'>學習</b><b class='flag-5'>第</b>3<b class='flag-5'>天</b>:【TS基礎類型】

    鴻蒙TypeScript入門學習8:【TypeScript 函數】

    函數是一組一起執行一個任務的語句。 您可以把代碼劃分到不同的函數中。如何劃分代碼到不同的函數中是由您來決定的,但在邏輯上,劃分通常是根據每個函數執行一個特定的任務來進行的。
    的頭像 發表于 04-03 14:54 ?644次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b>入門<b class='flag-5'>學習</b><b class='flag-5'>第</b>8<b class='flag-5'>天</b>:【<b class='flag-5'>TypeScript</b> 函數】

    鴻蒙TypeScript學習10:【String(字符串)】

    String 對象用于處理文本(字符串)。
    的頭像 發表于 04-08 14:32 ?1123次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>10<b class='flag-5'>天</b>:【String(字符串)】

    鴻蒙TypeScript學習12【Map對象

    Map 對象保存鍵值對,并且能夠記住鍵的原始插入順序。 任何值(對象或者原始值) 都可以作為一個鍵或一個值。
    的頭像 發表于 04-10 15:47 ?1543次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>12<b class='flag-5'>天</b>【Map<b class='flag-5'>對象</b>】

    鴻蒙TypeScript學習13:【元組】

    元組中允許存儲不同類型的元素,元組可以作為參數傳遞給函數。
    的頭像 發表于 04-11 14:43 ?735次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b><b class='flag-5'>第</b>13<b class='flag-5'>天</b>:【元組】

    鴻蒙TypeScript學習21:【聲明文件】

    TypeScript 作為 JavaScript 的超集,在開發過程中不可避免要引用其他第三方的 JavaScript 的庫。
    的頭像 發表于 04-19 15:02 ?836次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>TypeScript</b><b class='flag-5'>學習</b>21<b class='flag-5'>天</b>:【聲明文件】
    主站蜘蛛池模板: 色就色综合 | 一本道久久综合久久88 | 免费看国产曰批40分钟 | 美女裸露胸部100%无遮挡 | 成人国产AV精品久久久久 | 嫩草伊人久久精品少妇AV网站 | 同居了嫂子在线观看 | 2018三级网站免费观看 | 精品国产麻豆免费人成网站 | 韩国伦理片2018在线播放免费观看 | 青青青伊人 | 中文字幕亚洲无线码高清不卡 | 成人免费观看www视频 | 亚洲成AV人片一区二区不卡 | 肉肉的各种姿势高H细文 | 成人特级毛片 | 精品国产在线亚洲欧美 | YELLOW在线观看高清视频免费 | 最近高清日本免费 | 一抽一出BGM免费50分动漫 | 综合人妻久久一区二区精品 | 欧美另类一区 | 国产 在线 亚洲 欧美 动漫 | 国产在线精品视亚洲不卡 | 国产一区内射最近更新 | 乱辈通奷XXXXXHD猛交 | 火影忍者高清无码黄漫 | 国产精品第一综合首页 | 四虎4hu亚洲精品 | 亚洲国产AV一区二区三区四区 | 日韩精品一区二区三区色欲AV | 国产哺乳期奶水avav | 中文中幕无码亚洲视频 | 肉动漫无码无删减在线观看 | 富婆夜店找黑人猛男BD在线 | 芒果影院网站在线观看 | 亚洲中文字幕无码一去台湾 | 乱淫67194 | 久久综合九色综合国产 | 国产爱豆果冻传媒在线观看 | 久久看片网|

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品