【Vue】基礎(數據 & 計算屬性 & 方法)

来源:https://www.cnblogs.com/WilsonPan/archive/2020/04/22/12755476.html
-Advertisement-
Play Games

先從一個例子分析 <template> <div> <p>source array:{{numbers}}</p> <p>sorted array:{{sortArray()}}</p> <p>3 in array index : {{findIndex(3)}}</p> <p>totalNumbe ...


先從一個例子分析

<template>
  <div>
    <p>source array:{{numbers}}</p>
    <p>sorted array:{{sortArray()}}</p>
    <p>3 in array index : {{findIndex(3)}}</p>
    <p>totalNumbers : {{totalNumbers}}</p>
    <button @click="changeArray()">修改數組</button>
  </div>
</template>

<script>
export default {
  data() {
    return { numbers: [1, 5, 3, 9, 2, 4, 8] };
  },
  computed: {
    totalNumbers() {
      console.log("compute total");
      return this.numbers.reduce((total, val) => total + val);
    }
  },
  methods: {
    sortArray() {
      return this.numbers.slice(0).sort((a, b) => a - b);
    },
    findIndex(value) {
      console.log("find index");
      return this.numbers.findIndex(m => m === value);
    },
    changeArray() {
      for (let i = 0; i < this.numbers.length; i++) {
        this.$set(this.numbers, i, Math.floor(Math.random() * 100));
      }
    }
  }
};
</script>

 運行效果

 

1. 首先定義一組數組(數據)
2. 定義計算屬性,計算數組總和(計算屬性)
3. 定義3個方法,排序數組,查找指定值下標,修改數組(方法)

 

數據

data對象最適合純粹的數據:如果想將數據放在某處,然後在模板、方法或者計算屬性中使用

 

計算屬性

計算屬性適用於執行更加複雜的表達式,這些表達式往往太長或者需要頻繁地重覆使用

計算屬性會有緩存,依賴的數據沒有變化,會直接從緩存里取出,這個可以列印console.log,計算屬性可以驗證。所以計算屬性適合用於密集cpu計算。

計算屬性可以設置讀寫

total:{
    get(){
        ....
    }
    set(){
        ...
    }
}

 

方法

如果希望為模板添加函數功能時,最好使用方法,通常是傳遞參數,根據參數得到不同結果。


 

data對象 vs 方法 vs 計算屬性

 可讀可寫接受參數需要運算緩存
data 不能
方法
計算屬性

轉發請標明出處:https://www.cnblogs.com/WilsonPan/p/12755476.html


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

-Advertisement-
Play Games
更多相關文章
  • SDK開發中我們可能希望使用已有的第三方開源庫,比如在發送請求的功能上我們更希望用AFNetworking而非直接使用NSURLSession,又如在實現socket連接時我們更希望用SocketRocket而非自己從零實現。但如果我們直接把AFNetworking的源文件拖到靜態庫SDK里,而宿主 ...
  • long time no see,最近在總結一些平(應)常(付)用(面)到(試)的知識點,今天就跟大家聊了聊App體積優化這個事兒。 1.為什麼要做體積瘦身 別問!問就是為了應付面試。 哈哈,開個玩笑。大家生活中都會遇到一個場景,在某個需要緊急打開App的時候,發現使用的App半天打不開!WTF!而 ...
  • 一、承接連載5 1.註意事項 對於非String使用parseInt()或parseFloat(),會先將其轉換為String類型在進行操作。 var s1 = false; var s2 = parseInt(s1);//這裡會先轉換為字元串false,然後在進行解析數字 console.log( ...
  • 寫在前面 書籍介紹:《移動WEB前端高級開發實踐》這本書的內容涵蓋了移動Web前端開發中的各個關鍵技術環節。分別從HTML5、CSS3、JavaScript的ECMAScript5和ECMAScript6版本、移動端常用佈局方案、MV 類新時代框架、預編譯技術、性能優化、開發調試、混合式應用、單元測 ...
  • JavaScript基礎語法(3) 常量和變數 編程實質上就是在對各種各樣的數據進行處理。 在對數據進行處理的過程中,需要使用一個容器將數據保存起來,這樣就可以實現對容器中的數據進行處理。 根據容器中保存的數據在程式運行的過程中可不可以改變,容器分成了兩種:常量和變數 一、常量 常量就是一種恆定不變 ...
  • JavaScript基礎語法(2) 數據類型 js中有六種數據類型,包括五種基本數據類型(Number,String,Boolean,Undefined,Null),和一種複雜數據類型(Object)。在JS中,原始類型有6中: 一、數字類型Number (1)、整數: 可以是正數、0、負數,也可以 ...
  • svn和git區別: svn 集中式,需要聯網,需要一個中心伺服器放置最新的文件 git 分散式,不需要聯網 下載github客戶端並安裝完 克隆一個github項目到本地倉庫 修改完文件之後,先提交到本地倉庫,再push to origin 依舊提示要輸入用戶名和密碼 提交成功 如何回到過去: g ...
  • VSCode優點: 1、免費,開源 2、海量插件 3、輕量 去官網下載,傻瓜式安裝 漢化: 中文簡體安裝完成之後記得重啟 設置縮進方式:(根據自己的喜好) 主題設置: 文件--首選項--顏色主題 可以通過上下鍵切換顏色進行預覽 禁用主題: 可以選定主題進行禁用 圖標主題: 文件--首選項--文件圖標 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...