您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何搭建vue3.0項(xiàng)目”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何搭建vue3.0項(xiàng)目”這篇文章吧。
//安裝最新vue/cli yarn global add @vue/cli //或 npm install -g @vue/cli
用vue -V
查看安裝的版本號(hào)檢驗(yàn)是都成功安裝。
vue create my-project
? Please pick a preset: (Use arrow keys) default (babel, eslint) // 默認(rèn)選項(xiàng) Manually select features // 手動(dòng)選擇功能
很顯然以上兩個(gè)選擇都是Default默認(rèn)選項(xiàng),第一步我們選擇手動(dòng)自定義選項(xiàng)
? Please pick a preset: Manually select features ? Check the features needed for your project: (Press <space> to select, <a> to toggle all, <i> to invert selection) >( ) Babel // 代碼編譯 ( ) TypeScript // ts ( ) Progressive Web App (PWA) Support // 支持漸進(jìn)式網(wǎng)頁(yè)應(yīng)用程序 ( ) Router // vue路由 ( ) Vuex // 狀態(tài)管理模式 ( ) CSS Pre-processors // css預(yù)處理 ( ) Linter / Formatter // 代碼風(fēng)格、格式校驗(yàn) ( ) Unit Testing // 單元測(cè)試 ( ) E2E Testing // 端對(duì)端測(cè)試
這一步我們根據(jù)我們的項(xiàng)目需要去選擇我們需要的一些配置,a全選,空格單選,在我們需要的配置項(xiàng)敲空格即可,選完之后回車確認(rèn)
路由是否使用history模式,根據(jù)項(xiàng)目需求選擇
這一步我選擇的是node-sass預(yù)處理類型,根據(jù)自己項(xiàng)目需求去選擇css預(yù)編譯類型
? Pick a linter / formatter config: (Use arrow keys) > ESLint with error prevention only // 只進(jìn)行報(bào)錯(cuò)提醒 ESLint + Airbnb config // 不嚴(yán)謹(jǐn)模式 ESLint + Standard config // 正常模式 ESLint + Prettier // 嚴(yán)格模式 TSLint (deprecated) // TypeScript格式驗(yàn)證工具
這一步也可根據(jù)項(xiàng)目需求自行選擇
? Pick additional lint features: (Press <space> to select, <a> to toggle all, <i> to invert selection) >(*) Lint on save // 保存時(shí)檢測(cè) ( ) Lint and fix on commit // 修復(fù)和提交時(shí)檢測(cè)
選擇校驗(yàn)?zāi)J?,我選擇了保存時(shí)做校驗(yàn),也推薦大家選擇保存的時(shí)候去做校驗(yàn),也能及時(shí)的修改一些語(yǔ)法提示,比較方便去做語(yǔ)法調(diào)整
? Where do you prefer placing config for Babel, ESLint, etc.? (Use arrow keys) > In dedicated config files // 存放在專用配置文件中 In package.json // 存放在package.json中
選擇Babel, ESLint等自定義配置的存放位置。這里建議大家選擇第一個(gè)
是否保存當(dāng)前選擇的配置項(xiàng),如果當(dāng)前配置是經(jīng)常用到的配置,建議選擇y存儲(chǔ)一下當(dāng)前配置項(xiàng)。
到這一步我們的項(xiàng)目就已經(jīng)搭建好了根據(jù)提示,我們運(yùn)行一下項(xiàng)目。
cd may-project yarn serve
項(xiàng)目已經(jīng)跑起來(lái)了,這里我們要敲黑板了,如果現(xiàn)在我們直接用3.0的語(yǔ)法去開(kāi)發(fā)的話,會(huì)出現(xiàn)一個(gè)問(wèn)題,
<template> <div class="home"> {{msg}} </div> </template> <script> import { toRefs, reactive } from 'vue' export default { name: 'Home', setup: () => { const state = reactive({ msg: 'Hello World' }) return { ...toRefs(state) } } } </script>
我們直接渲染msg頁(yè)面會(huì)一直給我們報(bào)錯(cuò)說(shuō),msg變量沒(méi)有初始化
到這里我們不急,在看一下package.json,查看一下vue的版本,為什么不支持3.0的語(yǔ)法,結(jié)果問(wèn)題還真在這里
果然還是2.xx的版本號(hào),那么我們升級(jí)一下版本
vue add vue-next
升級(jí)完之后我們?cè)诳匆幌聀ackage.json,果然已經(jīng)是3.0.0-beta.1版本
升級(jí)好,這下我們?cè)?code>yarn serve在運(yùn)行一下我們的項(xiàng)目
果然現(xiàn)實(shí)總是啪啪的打臉,還是沒(méi)跑起來(lái),我們根據(jù)報(bào)錯(cuò)去看一下min.js
import { createApp } from 'vue' import App from './App.vue' import './registerServiceWorker' import router from './router' import store from './store' createApp(App).use(router).use(store).mount('#app')
我們稍作調(diào)整,不出所料我們的項(xiàng)目已經(jīng)正常運(yùn)行了!我們定義的msg字符串也渲染到了頁(yè)面上。
到此我們就跑通了我們的第一個(gè)vue3的項(xiàng)目
1.相比于vue2.0,性能有了明顯的提升;(據(jù)作者透露有了30%-300%的性能提升)
2.相比于vue2.0,打包體積明顯的縮小;采用Tree-shaking support將無(wú)用模塊剪輯,僅打包需要的,大大降低了打包的體積;
3.暴露了自定義渲染api,增加了可擴(kuò)展性;
4.底層完全采用typescript重寫(xiě),可以很好的支持ts;
5.新特性:增加組合式api( composition-api ),是我們可以以一種低侵入式的,更靈活的組合組件的邏輯;
以上是“如何搭建vue3.0項(xiàng)目”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。