學習 vue3 第一天 vue3簡介,創建vue3項目 Composition Api 初識

来源:https://www.cnblogs.com/LiuSan/archive/2022/11/25/16924588.html
-Advertisement-
Play Games

前言: 從今天開始來和大家一起學習 vue3 相信大家都不陌生,已經火了一段時間了,但是還是有不少人沒有學習,那就跟著六扇老師來簡單的入個門 廢話不多說,來開始今天的學習 Vue3 簡介: 2020年,9月,18日,Vue.js發佈3.0版本,耗時兩年多,2600+次提交,99位貢獻值 github ...


前言:

從今天開始來和大家一起學習 vue3 相信大家都不陌生,已經火了一段時間了,但是還是有不少人沒有學習,那就跟著六扇老師來簡單的入個門

廢話不多說,來開始今天的學習

Vue3 簡介:

2020年,9月,18日,Vue.js發佈3.0版本,耗時兩年多,2600+次提交,99位貢獻值

github 上的 tags 地址 :https://github.com/vuejs/core/releases/tag/v3.0.0

Vue3 帶來了什麼:

  1. 性能的提升,更快,更小,打包大小減少,初次渲染,更新渲染更快,記憶體減小
  2. 源碼的升級,使用 Proxy 代替 defineProperty 實現響應式,重新寫了虛擬 DOM 的實現 - 讓虛擬DO M 更快了 和 Tree-Shaking - 術語 幹掉了沒有使用的代碼,讓打包體積更小
  3. 擁抱了 TS ,vue3 更好的支持 TypeScript 
  4. 增加了新特性 

Composltlon API (組合 API)

  • setup 配置
  • ref 、 reactive
  • watch 、watchEffect
  • provide 、 inject

新的內置組件

  • Fragment
  • Teleport
  • Suspense

其他

新的生命周期鉤子

data 不再是對象,始終是一個函數

......

上邊的東西只是一個瞭解,混一個臉熟,不會,看不懂也沒有關係,後邊我們會一個個講,看一遍就會的,尤其是有 vue2 基礎的

說了怎麼,不如上手寫寫一遍,下麵我們就開始創建我們的 vue3

vue3 的創建:

創建 vue3 項目有兩種方式,一種是 vue 傳統的創建方式 一種是 vite 創建

  • 使用 vue-cli 創建
vue create vue3項目的name
  • 使用 vite 創建

當然這裡插一個題外話,什麼是 vite ----- 下一代前端構建工具差不多也是新一代了,現一代是webpack

vite 官網 :https://cn.vitejs.dev/

vite 有什麼優勢呢?

  • 開發環境中,無需打包操作,快速的冷啟動
  • 熱重載(HMR) 更輕量,快 (局部刷新)
  • 按需編譯,不用再等待整個應用的編譯

vite 優勢也差不多就是特點

傳統的構建相信用過 webpack 都知道,他是通過入口文件然後分析路由,再去分析模塊,都分析完了進行打包,然後告訴你伺服器準備好了

 

 

 vite 構建的工作模式,一上來就給用戶準備好伺服器,然後等待用戶請求,假如你發起了一個請求,然後 vite 會根據你的路徑 進入 入口文件然後找到 你的路由,分析該路由的模塊,然後給你 (動態的引入和代碼分割)

 

 

 用 vite 創建 vue3 

npm init vite-app vue3項目的name

當然 vite 創建是沒有依賴的,需要進入項目自己在 npm i

而且 vite 自配置的啟動 是 npm run dev

vite 會更快,不信你就都下載然後對比一下,實踐出真理

分析工程結構圖:

接下來讓我們分析一下 vue3 的工程結構 看看和 vue2 到底有什麼區別,我們以 vue-cli 下載好的 vue3 項目為例

打開文件,我們發現 vue3 的目錄結構和擺放位置都和 vue2 一樣沒什麼區別

只不過 vue3 文件裡面的一些語法和 vue2 不同

接下來我們來分析吧,如何分析?

main.js

首先我們打開項目的入口文件 main.js,一共寫了三行代碼,和 vue2 不同了吧

import { createApp } from 'vue'

import App from './App.vue'

createApp(App).mount('#app')

其中 import App from './App.vue' 我們見過在 vue2 中也有 意思是 引入所有組件的外殼組件,也就是所有組件的父親

import { createApp } from 'vue'  引入的不再是 Vue 構造函數了 是有一個 createApp 應用的實例對象,工廠函數

vue2 裡面 我們是 new 一個 vue 是一個構造函數

vue3  createApp 直接是 一個工廠函數 ,可以直接調用

有什麼不同呢?

來我們先回憶一下 vue2 中的寫法,

new Vue({

render:(h)=>{

return h(app)

}

}).$mount('#app')

我們拆解一下

const vm = new vue({render:h => h(app)})

vm.$mount('#app')

這是之前的寫法,接下來我們再把 createApp(App).mount('#app') 拆解

const app = createApp(App)

app.mount('#app')

這樣一對比是不是明白了

const app = createApp(App) 其實就是 創建實例應用對象  (和 vue2 裡面的 vm 類似 但 app 更輕)

app本質就是一個對象,裡面好多東西,vm裡面很多需要的不需要的都放在裡面,但 app 更精,減少了不需要的東西,所以“輕”了

App.vue

入口文件分析完了,我們按照代碼執行的方式,接下來分析 App.vue

進入 App.vue 和 vue2 一樣 template script style 沒區別

但是有一個地方發生變化了,那就是 template 裡邊沒有 div 了

vue3 組件中的模板結構可以沒有根標簽了(可以有,可以沒有)寫不寫都行了

Composition Api 初識:

composition 組合式 API 這概念有點長,有點多,不太好理解,先不講,暫時知道 composition 是組合式 AIP 就行

setup:

想玩 vue3 最好就是先學 setup,因為 setup 是 所有組合式API(comosition)的大舞臺

setup是什麼?

是 vue3 中一個新的配置項,一個函數,新增

頁面中需要的數據,也就是組件中所應用的數據,方法,生命周期,計算屬性等等等,都要配置寫在 setup 中

那怎麼配置呢,直接上手,寫代碼

export default {

name: 'App',

setup(){

let name = '六扇老師'

let age = '18'

// 方法

function sayHello(){ alert(`你們好,我是${name},今年${age}`) }

},

}

 和 vue2 不一樣了,我們 vue3 需要數據不用 data 了 直接寫就行了

setup 的返回值

寫完問題也就來了,誒六扇老師,我光寫完數據和方法了,我在組件中怎麼使用呢?

這裡就要說 setup 的返回值了,它有兩種一種是返回對象,一種是渲染函數

  • 若 setup 返回的是一個對象,則對象中的屬性,方法,直接就可以在模板中使用,和 vue2  一樣 (主要的內容)

setup(){

let name = '六扇老師'

let age = '18'

function sayHello(){ alert(`你們好,我是${name},今年${age}`) }

return { name, age, sayHello, }

},

我們直接在 setup 最後加一個 return 返回我們的 數據

然後再模板中和 vue2 一樣去引用,啟動項目

接下來我們再看 setup 的另一種返回值 

  • 返回一個渲染函數,可以自定義渲染內容(瞭解就行,不常用)

可以看到我們上邊寫的也不生效了,setup 返回的渲染函數為主了

當然返回的渲染函數前提需要引入 h ,渲染函數

題外話:vue3 是向下相容的,你可以在 vue3 中寫 vue2 語法的代碼,如果都寫一起得話,在 vue2 的方法中能獲取到 vue3 裡面 setup 的值

但是 在 vue3 中 不能獲取到 vue2 中 data 的值,而且如果有同名的,setup 優先

不建議與 vue2 配置混用,因為不知道什麼時候就不相容了,要不還學 vue3 幹嘛

setup 不能是一個 async 函數,因為返回值不再是 return 的對象,而是 promise, 模板看不到 retuen 裡面的數據對象

ref 函數

ref初識

我們在 vue2 的時候學過 ref ,是一個標簽屬性,給一個元素打標識,方便我們拿到,然後使用

但 vue3 裡面多了一個名為 ref 的函數

在學習 ref 函數之前我們先思考一個問題,上邊我們已經寫了數據,那如何修改呢?

老師我知道,直接寫一個函數,然後調用,讓 name 等於別的就修改了

我們可以看到,這樣寫了之後,數據是修改了,但是頁面卻沒有修改,也就是 vue 沒有發現

vue 不認識,也就是說你這樣定義的數據它只是普通的數據,根本不是響應式數據

那如何把普通的數據變成 vue 可以監測到的響應式數據呢,這就用到了 ref 函數

首先我們要先引入我們的 ref 函數

import {ref} from 'vue'

export default {

setup(){

let name = ref('六扇老師')

let age = ref('18')

function changeInfo(){

console.log(name,age)

}

return { name, age, changeInfo, }

}

我們看用 ref 函數更改完的數據,它是一個 RefImpl 的實例對象,那什麼是 RefImpl 對象?

我們拆開來看,Ref ---> reference 引用,Impl implement 實現

那 RefImpl 標準的稱呼就是"引用實現的實例對象",簡稱引用對象

然後我們看裡面,其他的值我們不看,就看一個 value 和 原型對象裡面的 set 和 get 

熟悉吧,和 vue2 一樣,拿到你的數據,然後通過 set 和 get 修改,然後頁面等等等

那怎麼修改呢,直接在你要修改的值後邊加上 .value 就修改完成了

 

 

小知識:template 組件裡面的發現 ref 對象會自動獲取到 value 值,所以直接寫就能獲取到值

ref 複雜對象

弄完基本類型數據,我們用 ref 寫一個對象類型

數據有了,那我們怎麼更改呢,其實也簡單,看圖我也經把 job.value 列印出來了

直接 job.value.type = 什麼值,就可以更改了

那問題來了 ref 加工之後不是都 RefImpl 對象嗎,為什麼 job.value 變成 Proxy 對象了呢,帶著這個問題,往下看 reactive 函數

總結:

ref 的作用,定義了一個響應式數據。創建了一個包含響應式數據的引用對象(reference對象,簡稱 ref 對象)

接受的數據可以是:基本類型,也可以是:對象類型

基本類型的數據:和 vue2 一樣響應式依然是靠 Object.defineProperty() 的 get 與 set 完成的

對象類型的數據:內部 求助 了 vue3 中的一個新函數 reactive 函數

題外話:vue3 接受到 對象類型的數據,底層就是 用 ES6 新語法 Proxy 來處理的,但是在 vue3 中並沒有直接使用,而是被封裝到 reactive 函數裡面 

reactive 函數

reactive 只能定義對象類型和數組的響應式數據 (基本類型用 ref ),之所以 ref 可以是因為 ref 內部求助了 reactive

用完 reactive 之後就和正常使用一樣了,直接點就行

當然數組也是同理,直接放在裡面寫就行了,對象怎麼用他怎麼用,而且還能直接通過索引去改,這是 vue2 辦不到的

let arr = reactive(["學習","喝酒","燙頭"])

function changeInfo(){

arr[0] = "抽煙"

}

reactive 的語法:

const 代理對象 = reactive(原對象),接受到一個對象或數組,返回一個代理對象(Proxy的實例對象)

reactive 定義的響應式數據是更深層次的,不管有多深都能點出來

內部是通過 ES6 的 Proxy 實現,通過代理對象操作原對內部數據進行操作,並且這種操作是可以被 vue 所捕獲到的,也就是我們說的數據劫持

題外話:

學到這裡有同學該問了,那老師這樣寫太墨跡了,一會 ref . vaule 一會 reactive 不點咋解決呢

還是那句話,代碼是死的人是活的,就像我們這幾個數據,你可以直接這樣去寫

 

 這樣是不是語法語義都正確了,而且還省事了,但是我還是覺得有點麻煩,不想點來點去的,別急留一個問題,我們下章再講


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

-Advertisement-
Play Games
更多相關文章
  • Docker和Docker-Compose簡單搭建與基本設置 一、搭建 Docker 1.第一步當然是看官方文檔 2.然後發現一大堆手動搭建的教程(然後小白就這樣搭建了),然後發現最後有一鍵搭建腳本 curl -fsSL https://get.docker.com -o get-docker.sh ...
  • 字元設備是按照位元組流進行讀寫操作的設備,讀寫數據是分先後順序的。常見的點燈、按鍵、 IIC、 SPI和LCD 等都是字元設備 。 字元設備驅動開發步驟: 總體思路: 定義並初始化一個字元設備 -1、定義一個字元設備—>struct cdev 2、定義並初始化字元設備的文件操作集—>struct fi ...
  • 使用的MCU型號為 AIR32F103CCT6. 通過工作機制和示例代碼, 說明如何使用AIR32自帶的記憶體實現簡單的語音錄製和播放功能, 以及使用 ADPCM 對音頻數據進行壓縮, 提高錄製時長. 通過這些機制, 可以快速擴充為實用的錄製設備, 例如外掛I2C或SPI存儲, 或提升無線傳輸的音質,... ...
  • Python基礎之MySQL資料庫 一、SQL語句常用查詢方法 前期數據準備 ​ 為了更加直觀的展示、演示SQL語句查詢關鍵字,需導入下列表格與記錄(數據) ​ 模擬公司,導入創建公司員工表,表內包含:ID、姓名、年齡、工作時間、崗位 創建人員表格: create table emp( id int ...
  • 在 4.2 版本及更高版本中,MongoDB 提供了事務的支持,並且在其是分散式資料庫的基礎上,提供了支持跨多個操作、集合、資料庫、文檔和分片的 ACID 事務。 ...
  • 一、什麼是數據湖? 在探討數據湖技術或如何構建數據湖之前,我們需要先明確,什麼是數據湖? 數據湖的起源,應該追溯到2010年10月。基於對半結構化、非結構化存儲的需求,同時為了推廣自家的Pentaho產品以及Hadoop,2010年Pentaho的創始人兼CTO James Dixon首次提出了數據 ...
  • 華為開發者大會2022(HDC)上,HMS Core手語數字人以全新形象亮相,併在直播中完成了長達3個多小時的實時手語翻譯,向線上線下超過一千萬的觀眾提供了專業、實時、準確的手語翻譯服務,為聽障人士提供了無障礙參會體驗。面對專業性強且辭彙量大的科技大會,HMS Core手語數字人是如何準確且流暢地打 ...
  • vuex是大家使用vue時大多數都會選擇的,但是當頁面刷新之後vuex數據會丟失,下麵這篇文章主要給大家介紹了關於vuex頁面刷新數據丟失問題的四種解決方式,需要的朋友可以參考下 為什麼說刷新頁面vuex的數據會丟失 刷新頁面vuex的數據會丟失屬於正常現象,因為JS的數據都是保存在瀏覽器的堆棧記憶體 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...