侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

在Vue2与Vue3中构建相同的组件

前端  /  管理员 发布于 6年前   350

4月16日,vue 开发团队终于在今天发布了 3.0-beta.1 版本,也就是测试版。通常来说,从测试版到正式版,只会修复 bug,不会引入新功能,或者删改老功能。所以,如果你对新版本非常感兴趣,或者有新项目即将上马,不妨尝试一下新版本。

随着vue3即将发布,许多人都在想“ Vue2与Vue3有何不同?”

为了显示这些更改,我们将在Vue2和Vue3中构建一个简单的表单组件。

在本文结尾,你将了解Vue2和Vue3之间的主要编程差异,并逐步成为一名更好的开发人员。


创建我们的模板

对于大多数组件,Vue2和Vue3中的代码即使不完全相同,也是非常相似的。但是,Vue3支持 Fragments ,这意味着组件可以具有多个根节点。

在渲染列表中的组件以删除不必要的包装div元素时,这特别有用。但是,在这种情况下,我们将为两个版本的Form组件保留一个根节点。

Vue2

<template>  <div class='form-element'>    <h2> {{ title }} </h2>    <input type='text' v-model='username' placeholder='Username' />        <input type='password' v-model='password' placeholder='Password' />    <button @click='login'>      Submit    </button>    <p>       Values: {{ username + ' ' + password }}    </p>  </div></template>

唯一真正的区别是我们访问数据的方式。在Vue3中,我们的响应式数据都包装在响应式状态变量中——因此我们需要访问该状态变量以获取我们的值。

Vue3

<template>  <div class='form-element'>    <h2> {{ state.title }} </h2>    <input type='text' v-model='state.username' placeholder='Username' />        <input type='password' v-model='state.password' placeholder='Password' />    <button @click='login'>      Submit    </button>    <p>       Values: {{ state.username + ' ' + state.password }}    </p>  </div></template>


设置Data

这是主要的区别——Vue2 Options API与Vue3 Composition API 。

Options API将我们的代码分为不同的属性:数据,计算属性,方法等。同时,Composition API允许我们按功能而不是属性类型对代码进行分组。

假设对于表单组件,我们只有两个数据属性: username 和 password 。

Vue2代码看起来是这样的——我们只需在 data 属性中放入两个值。

Vue2

export default {  props: {    title: String  },  data () {    return {      username: '',      password: ''    }  }}

在Vue 3.0中,我们必须投入更多的精力来使用一个新的 setup() 方法,所有的组件初始化都应该在这个方法中进行。

另外,为了使开发人员能够更好地控制响应式,我们可以直接访问Vue的响应式API。

创建响应式数据涉及三个步骤:

从Vue导入 reactive使用 reactive 方法声明我们的数据让我们的 setup() 方法返回 reactive 数据,以便我们的模板可以访问它

在代码方面,它将看起来像这样。

Vue3

import { reactive } from 'vue'export default {  props: {    title: String  },  setup () {    const state = reactive({      username: '',      password: ''    })    return { state }  }}

然后,在模板中,我们像 state.username 和 state.password 一样访问它们


在Vue2与Vue3中创建方法

Vue2 Options API有一个单独的方法部分。在其中,我们可以定义所有方法并以所需的任何方式组织它们。

Vue2

export default {  props: {    title: String  },  data () {    return {      username: '',      password: ''    }  },  methods: {    login () {      // login method    }  }}

Vue3 Composition API 中的setup方法也可以处理方法。它的工作方式与声明数据有些类似——我们必须先声明我们的方法,然后返回它,以便组件的其他部分可以访问它。

Vue3

export default {  props: {    title: String  },  setup () {    const state = reactive({      username: '',      password: ''    })    const login = () => {      // login method    }    return {       login,      state    }  }}


生命周期钩子函数

在Vue2中,我们可以直接从组件选项访问 生命周期钩子 函数。对于我们的示例,我们将等待 mounted 事件。

Vue2

export default {  props: {    title: String  },  data () {    return {      username: '',      password: ''    }  },  mounted () {    console.log('component mounted')  },  methods: {    login () {      // login method    }  }}

现在有了Vue3 Composition API,几乎所有内容都在 setup() 方法内部,这包括 mounted 的生命周期钩子。

但是,默认情况下不包括生命周期挂钩,因此我们必须导入 onMounted 方法,作为Vue3中调用的方法,这看起来与早期导入 reactive 相同。

然后,在我们的 setup() 方法中,可以通过将 onMounted 方法传递给函数来使用它。

Vue3

import { reactive, onMounted } from 'vue'export default {  props: {    title: String  },  setup () {    // ..    onMounted(() => {      console.log('component mounted')    })    // ...  }}


计算属性

让我们添加一个计算属性,将我们的用户名转换为小写字母。为了在Vue2中完成此操作,我们将一个计算字段添加到我们的options对象中。

Vue2

export default {  // ..   computed: {    lowerCaseUsername () {      return this.username.toLowerCase()    }  }}

Vue3的设计 允许开发人员导入他们使用的内容,而在项目中没有使用的不需要导入。本质上,他们不希望开发人员必须包含他们从未使用过的东西,这在Vue2中已经成为一个日益严重的问题。

因此,要在Vue3中使用计算属性,我们首先必须将 computed 导入到组件中。

然后,类似于我们之前创建 reactive 数据的方式,我们可以使一条 reactive 数据成为这样的计算值:

Vue3

import { reactive, onMounted, computed } from 'vue'export default {  props: {    title: String  },  setup () {    const state = reactive({      username: '',      password: '',      lowerCaseUsername: computed(() => state.username.toLowerCase())    })    // ...  }}


访问属性(Props)

访问Props带来了Vue2和Vue3之间的一个重要区别—— 这意味着完全不同的东西 。

在Vue2中,这几乎总是引用组件,而不是特定的属性,虽然这使事情表面上很容易,但它使类型支持成为一种痛苦。

以往,我们都可以轻松访问Props——让我们添加一个简单的示例,例如在mounted的钩子上打印出标题prop:

Vue2

mounted () {  console.log('title: ' + this.title)}

但是在Vue3中,我们不再使用它来访问Props、发出事件和获取属性。

相反, setup() 方法采用两个参数:

propscontext

使用props参数,上面的代码将如下所示。

Vue3

setup (props) {  // ...  onMounted(() => {    console.log('title: ' + props.title)  })  // ...}


发送事件(Emitting Events)

类似地,在Vue2中发出事件非常简单,但是Vue3为你提供了对如何访问属性/方法的更多控制。

例如,在我们的例子中,我们想在按下“Submit”按钮时向父组件发出登录事件。

Vue2代码只需要调用 this.$emit 并传入我们的有效参数对象即可。

Vue2

login () {  this.$emit('login', {    username: this.username,    password: this.password  }) }

然而,在Vue3中,我们现在知道这不再意味着同样的事情,所以我们必须做得不同。

幸运的是,上下文对象(context)公开了 emit ,这使我们拥有与此相同的东西。

我们要做的就是将 context 添加为 setup() 方法的第二个参数,我们将解构上下文对象,以使我们的代码更简洁。

然后,我们只需要调用emit发送事件即可。然后,像以前一样,emit方法采用两个参数:

事件名称与事件一起传递的有效参数对象

Vue3

setup (props, { emit }) {  // ...  const login = () => {    emit('login', {      username: state.username,      password: state.password    })  }  // ...}


最终的Vue2与Vue3代码!

如你所见,Vue2和Vue3中的所有概念都是相同的,但是我们访问属性的某些方式已经有所变化。

总的来说,我认为Vue3将帮助开发人员编写更有组织的代码——特别是在大型代码库中。这主要是因为Composition API允许你按特定功能将代码分组在一起,甚至可以将功能提取到自己的文件中,然后根据需要将其导入组件中。

Vue2中用于表单组件的完整代码:

<template>  <div class='form-element'>    <h2> {{ title }} </h2>    <input type='text' v-model='username' placeholder='Username' />        <input type='password' v-model='password' placeholder='Password' />    <button @click='login'>      Submit    </button>    <p>       Values: {{ username + ' ' + password }}    </p>  </div></template><script>export default {  props: {    title: String  },  data () {    return {      username: '',      password: ''    }  },  mounted () {    console.log('title: ' + this.title)  },  computed: {    lowerCaseUsername () {      return this.username.toLowerCase()    }  },  methods: {    login () {      this.$emit('login', {        username: this.username,        password: this.password      })    }  }}</script>

这是在Vue3中的完整代码:

<template>  <div class='form-element'>    <h2> {{ state.title }} </h2>    <input type='text' v-model='state.username' placeholder='Username' />        <input type='password' v-model='state.password' placeholder='Password' />    <button @click='login'>      Submit    </button>    <p>       Values: {{ state.username + ' ' + state.password }}    </p>  </div></template><script>import { reactive, onMounted, computed } from 'vue'export default {  props: {    title: String  },  setup (props, { emit }) {    const state = reactive({      username: '',      password: '',      lowerCaseUsername: computed(() => state.username.toLowerCase())    })    onMounted(() => {      console.log('title: ' + props.title)    })    const login = () => {      emit('login', {        username: state.username,        password: state.password      })    }    return {       login,      state    }  }}</script>

我希望本教程有助于重点介绍Vue代码在Vue3中看起来与众不同的某些方式。如有其他疑问,请留下你的意见!

原文: https://learnvue.co/2020/02/building-the-same-component-in-vue2-vs-vue3/
作者: Matt Maribojoc



  • 上一条:
    实现vue-router部分功能
    下一条:
    为什么说React 16是开发者的福音?
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客