最新版vue3+TypeScript开发入门到实战教程之vue3与vue2语法优劣对比

在vue3中能不能用vue2语法

回顾上篇文章创建vue3项目hello-world,将使用创建的项目。重新编写hello-world,先删除src文件夹,再创建src文件夹,编写vue2语法的hello-world,看能不能运行

  • 删除src文件夹
  • 创建src文件夹
  • 创建main.ts
  • 创建App.vue
  • 创建components文件夹
  • 在创建components内创建Car.vue

src项目结构如下

##main.ts引入挂载vue3

复制代码
import { createApp } from 'vue'
import App from './App.vue'
const app = createApp(App)
app.mount('#app')

根组件App引入组件Car

复制代码
<template>
  <Car/>
</template>
<script lang="ts">
import Car from './components/Car.vue'
export default {
  name: 'heiil',
  components: { Car }
}
</script>

Car组件使用vue2语法添加数据、方法

我们在组件中添加name,pirce,lowPrice,代表汽车品牌,价格,低价,并通过按钮,修改品牌名称和价格,查看最低价

复制代码
<template>
  <div class="car">
    <h2>品牌:{{ name }}</h2>
    <h2>价格:{{ price }}万</h2>
    <button @click="changeName">修改品牌</button>
    <button @click="changePrice">查看价格</button>
    <button @click="showLowPrice">查看低价</button>
  </div>
</template>
<script lang="ts">
export default{
  name: 'Car',
  data() {
    return {
      name: '奔驰',
      price: 100,
      lowPrice:80
    }

  },
  methods: {
    changeName() {
      this.name='宝马'

    },
    changePrice() {
      this.price += 10
    },
    showLowPrice() {
      alert(this.lowPrice+'万')
    }
  },
}
</script>
<style scoped>
.car{
  background-color:skyblue;
  box-shadow:  0 0 10px;
  border-radius: 10px;
  padding: 15px;
}
button{
  margin: 0 5px;
}
</style>

浏览器访问http://localhost:5173/,查看效果如下

调用的方法和属性,都可以正常应用。上述事例得出结论,在vue3可以用vue2语法。

vue2语法结构的特点

script语法结构

复制代码
# lang="ts"语法支持TypeScript
<script >
export default{
  name: 'Car',
  data() {
    return {
      name: '奔驰',
      price: 100,
      lowPrice:80
    }

  },
  methods: {
    changeName() {
      this.name='宝马'

    },
    changePrice() {
      this.price += 10
    },
    showLowPrice() {
      alert(this.lowPrice+'万')
    }
  },
}
</script>

vue2中语法是OptionsAPI,是选项式API,参看script代码 ,若给汽车再增加颜色属性和修改颜色的方法,需要分别在data里添加color属性和在methods中添加changeColor方法。若再增加重量、车长等等。

若此时该页面同时还有飞机的需求,汽车和飞机的属性和方法都混淆在一起,类似下图功能A为汽车功能B为飞机。

如图:

OptionsAPI的弊端

Options类型的API,数据、方法、计算属性等,是分散在 data、 methods、 computed中的, 若想新

增或者修改一个需求,就需要分别修改:data、methods、 computed。代码不便于维护和复用。

vue3新语法的优势

组合式 API (Composition API),所谓组合式API,就是将汽车所有的属性、方法、计算都放在一块,不分开;飞机的所有属性和方法也放到一块。这样的好处,增加修改汽车就到汽车的模块中,同理修改飞机就到飞机的模块中。如下图,将vue2中选项式(OptionsAPI)的写法转到vue3组合式 API (Composition API),每个颜色代表一个需求 ,如绿色代表飞机,蓝色代表汽车等。

vue3 语法的优势

组合式 API (Composition API),可以用函数的方式,更加优雅的组织代码,让相关功能的代码更加有序的组织在一起。

相关推荐
SouthRosefinch2 小时前
一、HTML简介与开发环境
开发语言·前端·html
全栈小52 小时前
【前端】Vue 组件开发中的枚举值验证:从一个Type属性错误说起
前端·javascript·vue.js
Joker Zxc2 小时前
【前端基础(Javascript部分)】4、JavaScript的分支语句
开发语言·前端·javascript
IT_陈寒2 小时前
JavaScript 性能优化的5个隐藏技巧:90%开发者都不知道的实战方案!
前端·人工智能·后端
꧁꫞꯭零꯭点꯭꫞꧂3 小时前
G6绘制机柜 以及机柜设备的demo
前端·javascript·vue.js
C澒3 小时前
供应链产研交付提效:前端多业务线新增样板间页面统计方案
前端·mr
可视之道3 小时前
低代码可视化平台的前端架构设计:从渲染引擎到插件系统
前端
南城书生3 小时前
Android Kotlin 协程原理分析
前端
Lee川3 小时前
🚀 JavaScript 内存大揭秘:从“栈堆搬家”到“闭包时空胶囊”
前端·javascript·面试