当前位置:   article > 正文

ts项目实例_vue 3.0 初体验 (项目搭建)

ts项目事件

9d8e9668ab22990f201bd23b8b92871e.png

6大亮点

54782247b53b7636be2036706d64bf9b.png

  • Performance:性能更比Vue 2.0强。

  • Tree shaking support:可以将无用模块“剪辑”,仅打包需要的。

  • Composition API:组合API

  • Fragment, Teleport, Suspense:“碎片”,TeleportProtal传送门,“悬念”

  • Better TypeScript support:更优秀的Ts支持

  • Custom Renderer API:暴露了自定义渲染API

现在就马上进入搭建吧 

包括了

  • 基于 vue-cli 快速搭建 Vue 3.0 项目

  • Vue 3.0 基本特性体验

  • 集成 vue-router 和 vuex 4.0

Vue 3.0 项目初始化

第一步,安装 vue-cli:

npm install -g @vue/cli

注意以下命令是错误的!

npm install -g vuenpm install -g vue-cli

安装成功后,我们即可使用 vue 命令,测试方法:

$ vue -V@vue/cli 4.3.1

第二步,初始化 vue 项目:

vue create vue-next-test
 

输入命令后,会出现命令行交互窗口,这里我们选择 Manually select features:

Vue CLI v4.3.1? Please pick a preset: default (babel, eslint) ❯ Manually select features
随后我们勾选:Router、Vuex、CSS Pre-processors 和 Linter / Formatter,这些都是开发商业级项目必须的:

65dcafef12bdc7bbb2ac4e48cdd781b4.png

注意:Vue 3.0 项目目前需要从 Vue 2.0 项目升级而来,

所以为了直接升级到 Vue 3.0 全家桶,

我们需要在 Vue 项目创建过程中勾选 Router 和 Vuex,

所以避免手动写初始化代码

升级 Vue 3.0 项目

目前创建 Vue 3.0 项目需要通过插件升级的方式来实现,

vue-cli 还没有直接支持,我们进入项目目录,并输入以下指令:

cd vue-next-testvue add vue-next

执行上述指令后,会自动安装 vue-cli-plugin-vue-next 插件(查看项目代码),该插件会完成以下操作:

  • 安装 Vue 3.0 依赖

  • 更新 Vue 3.0 webpack loader 配置,使其能够支持 .vue 文件构建(这点非常重要)

  • 创建 Vue 3.0 的模板代码

  • 自动将代码中的 Vue Router 和 Vuex 升级到 4.0 版本,如果未安装则不会升级

  • 自动生成 Vue Router 和 Vuex 模板代码

完成上述操作后,项目正式升级到 Vue 3.0,

注意该插件还不能支持 typescript,用 typescript 的同学还得再等等。(就是目前还不太支持TS)

Vue 3.0 基本特性体验

下面我们从项目开发的角度逐步体验 Vue 3.0 的开发流程

创建路由

项目开发中,我们通常需要创建新页面,然后添加路由配置,

我们在 /src/views 目录下创建 Test.vue:

c803fccba94150ae8f63225506469c34.png

之后在 /src/router/index.js 中创建路由配置:

8b01b848f3a8d450c550cdc391cd2a24.png

初始化 Vue Router 的过程与 3.0 版本变化不大,只是之前采用构造函数的方式,

这里改为使用 createRouter 来创建 Vue Router 实例,

配置的方法基本一致,配置完成后我们还需要在 App.vue 中增加链接到 Test.vue 的路由:

017eea19b0f6a0130eb5ce6810dc8c8e.png

启动项目:

npm run serve

c78f1311f1261ac889bc175e171d5a46.png

状态和事件绑定

Vue 3.0 中定义状态的方法改为类似 React Hooks 的方法,下面我们在 Test.vue 中定义一个状态 count:

4efa635d1d4136573ba37cb99e4cfefd.png

Vue 3.0 中初始化状态通过 setup 方法,

定义状态需要调用 ref 方法。接下来我们定义一个事件,用来更新 count 状态:

2291bc842e89b321a9b4c1d6c2cc6761.png

这里的 add 方法不再需要定义在 methods 中,

但注意更新 count 值的时候不能直接使用 count++,而应使用 count.value++,

更新代码后,点击按钮,count 的值就会更新了:

计算属性和监听器

Vue 3.0 中计算属性和监听器的实现依赖 computed 和 watch 方法:

727cac46f47ed1a88a29f03f8c0b2637.png

计算属性 computed 是一个方法,里面需要包含一个回调函数,当我们访问计算属性返回结果时,会自动获取回调函数的值:

const doubleCount = computed(() => count.value * 2)

监听器 watch 同样是一个方法,它包含 2 个参数,2 个参数都是 function:

watch(() => count.value,   val => {    console.log(`count is ${val}`)  })

第一个参数是监听的值,count.value 表示当 count.value 发生变化就会触发监听器的回调函数,即第二个参数,第二个参数可以执行监听时候的回调

如果是2 个以上的监听属性 就这样

watch(  [refA, () => refB.value],  ([a, b], [prevA, prevB]) => {    console.log(`a is: ${a}`)    console.log(`b is: ${b}`)  })

获取路由

Vue 3.0 中通过 getCurrentInstance 方法获取当前组件的实例,然后通过 ctx 属性获得当前上下文,

ctx.$router 是 Vue Router 实例,里面包含了 currentRoute 可以获取到当前的路由信息

7ccf88892435478a2767c44587975520.png

Vuex 集成

Vuex 的集成方法如下:

定义 Vuex 状态

第一步,修改 src/store/index.js 文件:

7ccf88892435478a2767c44587975520.png

import Vuex from 'vuex'export default Vuex.createStore({  state: {    test: {      a: 1    }  },  mutations: {    setTestA(state, value) {      state.test.a = value    }  },  actions: {  },  modules: {  }})

7ccf88892435478a2767c44587975520.png

Vuex 的语法和 API 基本没有改变,我们在 state 中创建了一个 test.a 状态,在 mutations 中添加了修改 state.test.a 状态的方法:setTestA

引用 Vuex 状态

第二步,在 Test.vue 中,通过计算属性使用 Vuex 状态:

ed8fb7566a6ef85dd6e68cd6e5bab979.png

这里我们通过计算属性来引用 Vuex 中的状态:

const a = computed(() => ctx.$store.state.test.a)

ctx 是上节中我们提到的当前组件实例

更新 Vuex 状态

更新 Vuex 状态仍然使用 commit 方法,这点和 Vuex 3.0 版本一致:

24d35b6c84ff1e4e335e4cdbf3ff167b.png

这里我们点击 update a 按钮后,会触发 update 方法,此时会通过 ctx.$store.commit 调用 setTestA 方法,将 count 的值覆盖 state.test.a 的值

总的效果呢是这样的:

8fb807bb5c8084a7c2b1e870ad5d095c.png

总结下哈:

  vue3.0都写在setup里,以前的所有数据状态都写在data里,

所有方法都写在methods里,而现在可以根据功能模块把状态和方法等划分在一起,更利于模块化,

不过这样对代码习惯和质量要求更高了,初学者用3.0可能会写的更混乱

 貌似 vue逐渐react化,存在即合理对吧 哈哈

好怕vuex会被provide和inject特性给替换掉。 

继续搞吧 哈哈

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/1015129
推荐阅读
相关标签
  

闽ICP备14008679号