欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3.0 項目搭建和使用流程

 更新時間:2021年11月22日 16:33:35   作者:梳碧湖的砍柴人  
這篇文章主要介紹了vue3.0 項目搭建和使用流程,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下

最近在重構(gòu)一個老項目,領(lǐng)導(dǎo)要求使用新的技術(shù)棧。好吧,是時候秀一波我新學的vue3.0了。

不多bb,開始我的表演。。。(以下只是我自己個人的理解和使用習慣,僅供參考哦)

一:項目搭建

1. 可以自己配置vite,但是為了節(jié)省時間,我就使用腳手架直接搭建。(有興趣可以研究一下vite,還是很香的)

2. 項目生成:iTerm下: vue create myproject

之后根據(jù)自己的要求選擇不同的配置

選擇我們需要的3.x

之后按照要求配置一下router,已經(jīng)pack.json 。。。 然后npm run serve

ok。一個基本的3.0項目搭建完成,結(jié)束。(那是不可能的)

二: 目錄結(jié)構(gòu)

原始的目錄結(jié)構(gòu)如下所示:

為了方便數(shù)據(jù)管理,我們需要自定義一些其他的文件。下面是一個簡單的demo結(jié)構(gòu):

hooks用來定義一些公共組件的方法,可以在多個組件里面復(fù)用,也可以和vuex聯(lián)用。

typing定義一些你需要使用的ts類型。比如:

根據(jù)不同的組件拆分不同的類型,然后統(tǒng)一在index中導(dǎo)出。index中可以定義一些公共的類型。

request定義一些http請求。

base.ts基本路徑

api.ts合集api??

http.ts 可以做一下axios請求攔截和配置一下環(huán)境。(development, product)

整體配置大致就是這樣,把api,以及ts類型集中起來,更方便之后的管理。

在組件內(nèi)部也需要拆分:

這是一個about頁面。分為.vue文件和一個內(nèi)部Hooks的文件夾。.vue文件是基本demo結(jié)構(gòu)。hooks里面根據(jù)不同的功能拆分不同的文件。比如:listDownHooks.ts文件就是用來出來下拉菜單的方法集合。還可以單獨拆分一個樣式文件,(我覺得有點麻煩就沒做..)

目錄結(jié)構(gòu)就是這樣。先在typing定義基本的數(shù)據(jù)類型,然后再每個組件下的Hooks里面的方法中引入之后在.vue文件里面使用對應(yīng)的方法。

三: Composition Api

Composition Api是一組基于功能的附加API,可以靈活地組合組件邏輯。配合ts食用更佳~~~

1. defineComponent

從Composition Api中解構(gòu)出來,配合ts。 定義一個組件:

export default?defineComponent({});

如果你不使用ts,也可以使用export default {} 的寫法。

2. setup

Composition Api核心的部分,是vue3.0的亮點。替代之前beforeCreate和created生命周期。

可以在setup中初始化一些響應(yīng)式數(shù)據(jù)。

setup(props, ctx) 接受兩個參數(shù),props和ctx(上下文).

props是傳統(tǒng)的父傳子數(shù)據(jù)。不建議在setup中解構(gòu)props,這樣會使props失去響應(yīng)。

ctx中可以解構(gòu)出,slots,attrs, emit,用法類同于2.0。

3. ref和reactive

用來創(chuàng)建響應(yīng)式數(shù)據(jù)的方法。從vue中解構(gòu)出來? =>? ??import {ref, reactive} from 'vue';

ref使用:

import {ref, defineComponent} from 'vue';
export default defineComponent({
 setup() {
  const number = ref(0);
  console.log(number); 
  return {
   number
  }
 }
})

通過ref創(chuàng)建一個響應(yīng)式數(shù)據(jù),console看一下。

這是一個ref式響應(yīng)數(shù)據(jù),我們在操作的時候通過number.value來操作數(shù)據(jù),然后把結(jié)果return回去。

ref 聲明基本類型和引用類型的區(qū)別?

ref聲明基本類型,是創(chuàng)建了一個ref的響應(yīng)式對象

ref聲明引用類型,也是創(chuàng)建了一個ref的對象,但是內(nèi)部是用reactive方法包裝的響應(yīng)式對象

如果你的ref對象被更改在一個reactive里面,可以直接通過key,value方法獲取

reactive使用:

import {reactive, defineComponent, toRefs} from 'vue';
export default defineComponent({
 setup() {
  const obj = reactive({   
    menuList: [] as Array<T>
   });
  console.log(number); 
  return {
    ...toRefs(obj);
  }
 }
})

創(chuàng)建一個proxy式的響應(yīng)數(shù)據(jù)。通過toRefs將數(shù)據(jù)return回去。內(nèi)部是這樣的:

個人覺得:一些基本類型可以多使用ref定義,對于一個整體的定義,可以使用reactive。

其他:

其他的一些常用的方法比如:computed, watch,等其實用法和2.0差不多。這里不多描述。

四: 基本使用:

用一個基本的新聞列表為例。

主要就是在mounted階段調(diào)取數(shù)據(jù),在翻頁的時候刷新數(shù)據(jù)。

目錄:

src -> views -> News -> Hook ->newsListHook.ts (用來處理列表數(shù)據(jù))

在文件中定義一下原始數(shù)據(jù)。

let dataSource = reactive({
 list: [] as Array<InewsList> // InewsList是數(shù)據(jù)類型 
});

定義一個newsList() 方法,內(nèi)部包含一個getList方法用來獲取接口數(shù)據(jù)。一個方法分頁請求時候觸發(fā),把getList在mounted掛載。之后將數(shù)據(jù)和方法return出去。代碼如下:

/** * 1. 列表請求數(shù)據(jù) */import api from '../../../request/api';
import {reactive, onMounted} from 'vue';
import {InewsList} from '../../../typing';
export function newsList(): object { 
 let dataSource = reactive({list: [] as Array<InewsList>});
 function getList(obj: object): void {
  api.newsList(obj).then(res => {
   dataSource.list = res.data.data; })
 };
 function onChange(e: any): void {
  let start = e || 10;
  const obj = {start,num: 10};
  getList(obj);
 }; 
 onMounted(() => {
  const startObj = {start: 1, num: 10};
  getList(startObj);
 }); 
 return {
  dataSource,
  getList,
  onChange
}}

之后src -> views -> News ->News.vue文件中使用。

import {newsList} from './Hook/newslistHook';
export default defineComponent({ 
  name: 'news',
  setup() { 
  const list = newsList();
  return {
   ...list // list中包含著所有定義的數(shù)據(jù)和方法。
  } 
}})

console一下list:

這樣就可以直接在vue文件中渲染使用了。

總結(jié)一下:把需要用的方還有一些事件(click, mousedown, keyup...)可以放在hook中執(zhí)行,vue文件就是用來數(shù)據(jù)渲染。

項目中使用到了antd的Vue框架,大家在使用的時候最好按需加載。畢竟antd太大啦。

import Menu from 'ant-design-vue/es/menu/index'
import Select from 'ant-design-vue/es/select/index'
createApp(App).use(store).use(router).use(Menu).use(Select)

好啦,就到這里啦。新人嘗試寫vue3.0,不足地方多多指出哦。

以上就是vue3.0 項目搭建和使用流程的詳細內(nèi)容,更多關(guān)于vue3.0 項目搭建和使用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)

    vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘Combin

    這篇文章主要介紹了vscode中的vue項目報錯Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Vue自定義復(fù)制指令 v-copy功能的實現(xiàn)

    Vue自定義復(fù)制指令 v-copy功能的實現(xiàn)

    這篇文章主要介紹了Vue自定義復(fù)制指令 v-copy,使用自定義指令創(chuàng)建一個點擊復(fù)制文本功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • 使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能

    使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能

    這篇文章主要介紹了使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能,需要的朋友可以參考下
    2019-04-04
  • 在Vue環(huán)境下利用worker運行interval計時器的步驟

    在Vue環(huán)境下利用worker運行interval計時器的步驟

    這篇文章主要介紹了在Vue環(huán)境下利用worker運行interval計時器的步驟,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • vue-router的hooks用法詳解

    vue-router的hooks用法詳解

    這篇文章主要介紹了vue-router的hooks用法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Vue?el-table實現(xiàn)右鍵菜單功能

    Vue?el-table實現(xiàn)右鍵菜單功能

    這篇文章主要為大家詳細介紹了Vue?el-table實現(xiàn)右鍵菜單功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue中的inject學習教程

    vue中的inject學習教程

    本文通過實例代碼給大家介紹了vue中的inject學習教程,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2019-04-04
  • vue使用map代替Aarry數(shù)組循環(huán)遍歷的方法

    vue使用map代替Aarry數(shù)組循環(huán)遍歷的方法

    這篇文章主要介紹了vue使用map代替Aarry數(shù)組循環(huán)遍歷的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • 使用Vue手寫一個對話框

    使用Vue手寫一個對話框

    相信大家之前都寫過一些組件,尤其是這樣的彈窗組件,這篇文章主要來和大家聊聊如何使用Vue手寫一個對話框,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-04-04
  • Vue項目中使用jsonp抓取跨域數(shù)據(jù)的方法

    Vue項目中使用jsonp抓取跨域數(shù)據(jù)的方法

    這篇文章主要介紹了Vue項目中使用jsonp抓取跨域數(shù)據(jù)的方法,本文通過實例代碼講解的非常詳細,需要的朋友可以參考下
    2019-11-11

最新評論