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

詳解vite+ts快速搭建vue3項(xiàng)目以及介紹相關(guān)特性

 更新時(shí)間:2021年02月25日 09:51:52   作者:筱月  
這篇文章主要介紹了vite+ts快速搭建vue3項(xiàng)目以及介紹相關(guān)特性,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

vite

尤大在 Vue 3.0 beta 直播中推薦了 vite 的工具,強(qiáng)調(diào):針對(duì)Vue單頁(yè)面組件的無(wú)打包開(kāi)發(fā)服務(wù)器,可以直接在瀏覽器運(yùn)行請(qǐng)求的 vue 文件

很新穎,這篇博客用它來(lái)搭建一個(gè) vue3 的項(xiàng)目試試

Vite 是面向現(xiàn)代瀏覽器,基于原生模塊系統(tǒng) ESModule 實(shí)現(xiàn)了按需編譯的 Web 開(kāi)發(fā)構(gòu)建工具。在生產(chǎn)環(huán)境下基于 Rollup 打包

  • 快速冷啟動(dòng)服務(wù)器
  • 即時(shí)熱模塊更換(HMR)
  • 真正的按需編譯

node >= 10.16.0

搭建

使用 vite 搭建項(xiàng)目

npm init vite-app <project-name>

安裝 typescript、vue-router@next、axios、eslint-plugin-vue、sass 等相關(guān)插件

配置

vite.config.ts

vite.config.ts 相當(dāng)于 @vue-cli 項(xiàng)目中的 vue.config.js

我這簡(jiǎn)單配置一下:

import path from 'path'

module.exports = {
 alias: {
 '/@/': path.resolve(__dirname, './src')
 },
 optimizeDeps: {
 include: ['lodash']
 },
 proxy: {}
}

Router

在 src 下新建 router 文件夾,并在文件夾內(nèi)創(chuàng)建 index.ts

import { createRouter, createWebHistory } from 'vue-router'

const routes = [
 {
 path: '/',
 name: 'Home',
 component: () => import('/@/views/Home.vue')
 },
 {
 path: '/lifeCycle',
 name: 'lifeCycle',
 component: () => import('/@/views/LifeCycle.vue')
 }
]

export default createRouter({
 history: createWebHistory('/krry/'),
 routes
})

ts types

項(xiàng)目根目錄下新建 tsconfig.json 寫(xiě)入相關(guān)配置

{
 "compilerOptions": {
 ...// 其他配置
 "paths": {
  "/@/*": [
  "src/*"
  ]
 },
 "lib": [
  "esnext",
  "dom",
  "dom.iterable",
  "scripthost"
 ]
 },
 "include": [
 "src/**/*.ts",
 "src/**/*.tsx",
 "src/**/*.vue",
 "src/types/images.d.ts",
 "tests/**/*.ts",
 "tests/**/*.tsx"
 ],
 "exclude": [
 "node_modules"
 ]
}

src 目錄下新建 types 文件夾,里面需要配置 ts 的類型

shims-vue.d.ts

declare module '*.vue' {}

images.d.ts

declare module '*.svg'
declare module '*.png'
declare module '*.jpg'
declare module '*.jpeg'
declare module '*.gif'
declare module '*.bmp'
declare module '*.tiff'

main.ts

import { createApp } from 'vue'
import router from '/@/router'

import App from '/@/App.vue'

const app = createApp(App)
app.use(router)
app.mount('#app')

然后就可以快樂(lè)地寫(xiě)代碼了

vue3 知識(shí)

setup

vue3 中用 setup 函數(shù)整合了所有的 api;只執(zhí)行一次,在生命周期函數(shù)前執(zhí)行,所以在 setup 函數(shù)中拿不到當(dāng)前實(shí)例 this,不能用 this 來(lái)調(diào)用 vue2 寫(xiě)法中定義的方法

它將接受兩個(gè)參數(shù):props、context

// props - 組件接受到的屬性 context - 上下文 
setup(props, context) {
 return {
 // 要綁定的數(shù)據(jù)和方法
 }
}

props

setup 函數(shù)中的 props 是響應(yīng)式的,當(dāng)傳入新的 prop 時(shí),它將被更新
但是,因?yàn)?props 是響應(yīng)式的,不能使用 ES6 解構(gòu),因?yàn)樗鼤?huì)消除 prop 的響應(yīng)性

如果需要解構(gòu) prop,可以通過(guò)使用 setup 函數(shù)中的 toRefs 來(lái)安全地完成此操作

import { toRefs } from 'vue'

setup(props) {
 const { title } = toRefs(props)
 console.log(title.value)
}

context

context 暴露三個(gè)組件的 property:{ attrs, slots, emit }
它是一個(gè)普通的 JavaScript 對(duì)象,不是響應(yīng)式的,這意味著你可以安全地對(duì) context 使用 ES6 解構(gòu)

生命周期

通過(guò)在生命周期鉤子前面加上 “on” 來(lái)訪問(wèn)組件的生命周期鉤子

因?yàn)?setup 是圍繞 beforeCreate 和 created 生命周期鉤子運(yùn)行的,所以不需要顯式地定義它們
換句話說(shuō),在這兩個(gè)鉤子中編寫(xiě)的任何代碼都應(yīng)該直接在 setup 函數(shù)中編寫(xiě)

setup() {
 onMounted(() => {
 console.log('組件掛載')
 })

 onUnmounted(() => {
 console.log('組件卸載')
 })

 onUpdated(() => {
 console.log('組件更新')
 })

 onBeforeUpdate(() => {
 console.log('組件將要更新')
 })

 onActivated(() => {
 console.log('keepAlive 組件 激活')
 })

 onDeactivated(() => {
 console.log('keepAlive 組件 非激活')
 })

 return {}
}

ref、reactive

ref 可以將某個(gè)普通值包裝成響應(yīng)式數(shù)據(jù),僅限于簡(jiǎn)單值,內(nèi)部是將值包裝成對(duì)象,再通過(guò) defineProperty 來(lái)處理的
通過(guò) ref 包裝的值,取值和設(shè)置值的時(shí)候,需用通過(guò) .value來(lái)進(jìn)行設(shè)置
可以用 ref 來(lái)獲取組件的引用,替代 this.$refs 的寫(xiě)法

reactive 對(duì)復(fù)雜數(shù)據(jù)進(jìn)行響應(yīng)式處理,它的返回值是一個(gè) proxy 對(duì)象,在 setup 函數(shù)中返回時(shí),可以用 toRefs 對(duì) proxy 對(duì)象進(jìn)行結(jié)構(gòu),方便在 template 中使用

使用如下:

<template>
 <div>
 <div>
  <ul v-for="ele in eleList" :key="ele.id">
  <li>{{ ele.name }}</li>
  </ul>
  <button @click="addEle">添加</button>
 </div>
 <div>
  <ul v-for="ele in todoList" :key="ele.id">
  <li>{{ ele.name }}</li>
  </ul>
  <button @click="addTodo">添加</button>
 </div>
 </div>
</template>

<script>
import { ref, reactive, toRefs } from 'vue'

export default {
 setup() {
 // ref
 const eleList = ref([])
 function addEle() {
  let len = eleList.value.length
  eleList.value.push({
  id: len,
  name: 'ref 自增' + len
  })
 }

 // reactive
 const dataObj = reactive({
  todoList: []
 })
 function addTodo() {
  let len = dataObj.todoList.length
  dataObj.todoList.push({
  id: len,
  name: 'reactive 自增' + len
  })
 }

 return {
  eleList,
  addEle,
  addTodo,
  ...toRefs(dataObj)
 }
 }
}
</script>

computed、watch

// computed
let sum = computed(() => dataObj.todoList.length + eleList.value.length)
console.log('setup引用computed要.value:' + sum.value)

// watch
watch(
 eleList,
 (curVal, oldVal) => {
 console.log('監(jiān)聽(tīng)器:', curVal, oldVal)
 },
 {
 deep: true
 }
)

watchEffect

響應(yīng)式地跟蹤函數(shù)中引用的響應(yīng)式數(shù)據(jù),當(dāng)響應(yīng)式數(shù)據(jù)改變時(shí),會(huì)重新執(zhí)行函數(shù)

const count = ref(0)
// 當(dāng) count 的值被修改時(shí),會(huì)執(zhí)行回調(diào)
const stop = watchEffect(() => console.log(count.value))

// 停止監(jiān)聽(tīng)
stop()

還可以停止監(jiān)聽(tīng),watchEffect 返回一個(gè)函數(shù),執(zhí)行后可以停止監(jiān)聽(tīng)

與 vue2 一樣:

const unwatch = this.$watch('say', curVal => {})

// 停止監(jiān)聽(tīng)
unwatch()

useRoute、useRouter

import {useRoute, useRouter} from 'vue-router'

const route = useRoute() // 相當(dāng)于 vue2 中的 this.$route
const router = useRouter() // 相當(dāng)于 vue2 中的 this.$router

route   用于獲取當(dāng)前路由數(shù)據(jù)
router  用于路由跳轉(zhuǎn)

vuex

使用 useStore 來(lái)獲取 store 對(duì)象 從 vuex 中取值時(shí),要注意必須使用 computed 進(jìn)行包裝,這樣 vuex 中狀態(tài)修改后才能在頁(yè)面中響應(yīng)

import {useStore} from 'vuex'

setup(){
 const store = useStore() // 相當(dāng)于 vue2 中的 this.$store
 store.dispatch() // 通過(guò) store 對(duì)象來(lái) dispatch 派發(fā)異步任務(wù)
 store.commit() // commit 修改 store 數(shù)據(jù)
 
 let category = computed(() => store.state.home.currentCagegory
 return { category }
}

到此這篇關(guān)于vite+ts快速搭建vue3項(xiàng)目以及介紹相關(guān)特性的文章就介紹到這了,更多相關(guān)vite+ts搭建vue3內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue過(guò)濾器filters如何使用

    Vue過(guò)濾器filters如何使用

    Vue過(guò)濾器filters用于一些常見(jiàn)的文本格式化,通過(guò)過(guò)濾器可以進(jìn)行處理成自己想要展示出來(lái)的格式,由“管道”符號(hào)指示,本文給大家介紹Vue過(guò)濾器filters使用方式,感興趣的朋友一起看看吧
    2023-10-10
  • vue腳手架vue-cli的卸載與安裝方式

    vue腳手架vue-cli的卸載與安裝方式

    pm是nodejs的包管理和分發(fā)工具,它可以讓javascript開(kāi)發(fā)者能夠更加輕松的共享代碼和共用代碼片段,下面這篇文章主要給大家介紹了關(guān)于vue腳手架vue-cli卸載與安裝的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • vue cli 3.0 使用全過(guò)程解析

    vue cli 3.0 使用全過(guò)程解析

    這篇文章主要介紹了vue-cli 3.0 使用全過(guò)程,本文通過(guò)項(xiàng)目實(shí)例相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2018-06-06
  • Vue.js路由實(shí)現(xiàn)選項(xiàng)卡簡(jiǎn)單實(shí)例

    Vue.js路由實(shí)現(xiàn)選項(xiàng)卡簡(jiǎn)單實(shí)例

    這篇文章主要為大家詳細(xì)介紹了Vue.js路由實(shí)現(xiàn)選項(xiàng)卡簡(jiǎn)單實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 詳解Vue中使用v-for語(yǔ)句拋出錯(cuò)誤的解決方案

    詳解Vue中使用v-for語(yǔ)句拋出錯(cuò)誤的解決方案

    本篇文章主要介紹了詳解Vue中使用v-for語(yǔ)句拋出錯(cuò)誤的解決方案,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 解決Vue路由導(dǎo)航報(bào)錯(cuò):NavigationDuplicated:?Avoided?redundant?navigation?to?current?location

    解決Vue路由導(dǎo)航報(bào)錯(cuò):NavigationDuplicated:?Avoided?redundant?navig

    這篇文章主要給大家介紹了關(guān)于解決Vue路由導(dǎo)航報(bào)錯(cuò):NavigationDuplicated:?Avoided?redundant?navigation?to?current?location的相關(guān)資料,這是最近做項(xiàng)目時(shí)候遇到的一個(gè)問(wèn)題,現(xiàn)將解決辦法分享出來(lái),需要的朋友可以參考下
    2023-01-01
  • vue?table表格中如何控制下拉框的顯示隱藏

    vue?table表格中如何控制下拉框的顯示隱藏

    這篇文章主要介紹了vue?table表格中如何控制下拉框的顯示隱藏問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue3使用axios并封裝axios請(qǐng)求的詳細(xì)步驟

    vue3使用axios并封裝axios請(qǐng)求的詳細(xì)步驟

    本篇文章分步驟給大家介紹了vue3使用axios并封裝axios請(qǐng)求的詳細(xì)步驟,結(jié)合實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友參考下吧
    2023-06-06
  • vue中使用props傳值的方法

    vue中使用props傳值的方法

    這篇文章主要介紹了vue中使用props傳值的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue+element+Java實(shí)現(xiàn)批量刪除功能

    vue+element+Java實(shí)現(xiàn)批量刪除功能

    這篇文章主要介紹了vue+element+Java實(shí)現(xiàn)批量刪除功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04

最新評(píng)論