Vue2 快速过度 Vue3 教程 (后端学习)

隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习Vue3的笔记

从 Vue 2 到 Vue 3,Vue.js 进行了全面的升级,带来了许多新特性、性能优化和开发体验的提升。以下是 Vue 2 到 Vue 3 的主要变化和核心改进:

一、Composition API

  • Vue 2 的 Options API:Vue 2 使用 data、methods、computed 等选项来组织代码,逻辑分散在不同的选项中。

  • Vue 3 的 Composition API:引入了 setup 函数,允许开发者将相关逻辑组织在一起,代码更清晰、更易复用。

    • 核心函数:refreactivecomputedwatch 等。

Vue 3 引入了 Composition API,提供了更好的代码组织方式,特别适用于大型项目。

Vue 2 (Options API)

<template>
  <div>{{ count }}</div>
  <button @click="increment">增加</button>
</template>

<script>
export default {
  data() {
    return {
      count: 0,
      user: {
        name: "张三",
        age: 25
      }
    };
  },
  methods: {
    increment() {
      this.count++;
    }
  }
};
</script>

Vue 3 (Composition API)

Vue 3 使用 setup(),可以直接在script setup 里声明 ref 变量,而不需要 data methods 选项。代码更简洁,逻辑更清晰。Vue 3 提供了 reactive()ref() 作为新的响应式 API。

  • reactive() 适用于对象,使整个对象都变成响应式。

  • ref() 适用于基本数据类型,如 const count = ref(0)。

<template>
  <div>{{ count }}</div>
  <button @click="increment">增加</button>
</template>

<script setup>
import { ref,reactive  } from "vue";

const count = ref(0);

const increment = () => {
  count.value++;
};

const user = reactive({
  name: "张三",
  age: 25
});
</script>

二、router

Vue 3 的 vue-router 也进行了升级,主要是 Vue Router 4 替代了 Vue 2 中的 Vue Router 3。以下是它们的主要不同点及代码对比。

创建 Router 实例的方式变化

Vue 2 (Vue Router 3)

在 Vue 2 中,我们通常这样创建路由:

import Vue from "vue";
import VueRouter from "vue-router";
import Home from "./views/Home.vue";
import About from "./views/About.vue";

Vue.use(VueRouter);

const routes = [
  { path: "/", component: Home },
  { path: "/about", component: About },
];

const router = new VueRouter({
  mode: "history",
  routes,
});

export default router;

然后在 main.js 中:

import Vue from "vue";
import App from "./App.vue";
import router from "./router";

new Vue({
  router,
  render: (h) => h(App),
}).$mount("#app");

Vue 3 (Vue Router 4)

Vue 3 使用 createRouter() createWebHistory() 来替代 new VueRouter()

import { createRouter, createWebHistory } from "vue-router";
import Home from "./views/Home.vue";
import About from "./views/About.vue";

const routes = [
  { path: "/", component: Home },
  { path: "/about", component: About },
];

const router = createRouter({
  history: createWebHistory(),
  routes,
});

export default router;

然后在 main.js 中:

import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";

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

区别:

  • Vue.use(VueRouter) 在 Vue 3 里不再使用,而是 app.use(router)。
  • createRouter() 代替了 new VueRouter()。
  • createWebHistory() 代替了 mode: “history”。

获取路由对象的方式

Vue 2

this.$route.path; // 获取当前路径
this.$router.push('/about'); // 跳转到 about 页面

Vue 3

Vue 3 仍然支持 this.$routethis.$router,但推荐在 Composition API 里使用 useRoute()useRouter()

<script setup>
import { useRoute, useRouter } from "vue-router";

const route = useRoute();
const router = useRouter();

console.log(route.path); // 获取当前路径

const goToAbout = () => {
  router.push("/about"); // 编程式导航
};
</script>

动态路由的变化

Vue 2

在 Vue 2 中,我们可以用 this.$route.params 获取动态参数:

const userId = this.$route.params.id; 

Vue 3

在 Vue 3 中,推荐使用 useRoute():

import { useRoute } from "vue-router";

const route = useRoute();
const userId = route.params.id;

三、 全局变量和方法

全局变量的定义

Vue 2:使用 Vue.prototype

在 Vue 2 中,我们通常使用 Vue.prototype 来定义全局变量:

import Vue from "vue";

Vue.prototype.$globalVar = "我是全局变量";

new Vue({
  el: "#app",
  created() {
    console.log(this.$globalVar); // 输出: 我是全局变量
  }
});

Vue 3:使用 app.config.globalProperties

Vue 3 移除了 Vue.prototype,改用 globalProperties:

import { createApp } from "vue";
import App from "./App.vue";

const app = createApp(App);
app.config.globalProperties.$globalVar = "我是全局变量";
app.mount("#app");

使用方式(在组件内访问):

<script setup>
import { getCurrentInstance } from "vue";

const { proxy } = getCurrentInstance();
console.log(proxy.$globalVar); // 输出: 我是全局变量
</script>

全局方法的定义

Vue 2:使用 Vue.prototype

Vue.prototype.$greet = function(name) {
  return `你好, ${name}`;
};

new Vue({
  created() {
    console.log(this.$greet("张三")); // 输出: 你好, 张三
  }
});

Vue 3:使用 globalProperties

app.config.globalProperties.$greet = (name) => `你好, ${name}`;

在组件内使用:

<script setup>
import { getCurrentInstance } from "vue";

const { proxy } = getCurrentInstance();
console.log(proxy.$greet("张三")); // 输出: 你好, 张三
</script>

四、生命周期

Vue 3 的生命周期钩子(Lifecycle Hooks)相较于 Vue 2 进行了调整,主要体现在以下几个方面:

  1. 选项式 API(Options API)和 Vue 2 基本一致
  2. 组合式 API(Composition API)使用 onMountedonUnmounted 等函数
  3. beforeDestroy 变成 onBeforeUnmountdestroyed 变成 onUnmounted

生命周期对比表

生命周期Vue 2Vue 3(Options API)Vue 3(Composition API)
创建前beforeCreatebeforeCreate-
创建后createdcreated-
挂载前beforeMountbeforeMount-
挂载后mountedmountedonMounted()
更新前beforeUpdatebeforeUpdateonBeforeUpdate()
更新后updatedupdatedonUpdated()
销毁前beforeDestroybeforeUnmountonBeforeUnmount()
销毁后destroyedunmountedonUnmounted()

Vue 3 的变化:

  • beforeDestroyonBeforeUnmount
  • destroyedonUnmounted
  • Vue 3 组合式 API 使用 onMountedonUnmounted 代替 mounteddestroyed

Options API 写法(Vue 3 仍支持 Vue 2 语法)

Vue 3 仍然支持 传统的生命周期写法:

<script>
export default {
  data() {
    return {
      message: "Hello Vue 3"
    };
  },
  beforeCreate() {
    console.log("beforeCreate");
  },
  created() {
    console.log("created");
  },
  beforeMount() {
    console.log("beforeMount");
  },
  mounted() {
    console.log("mounted");
  },
  beforeUpdate() {
    console.log("beforeUpdate");
  },
  updated() {
    console.log("updated");
  },
  beforeUnmount() {
    console.log("beforeUnmount");
  },
  unmounted() {
    console.log("unmounted");
  }
};
</script>

区别:

  • beforeDestroy 变成了 beforeUnmount
  • destroyed 变成了 unmounted

Composition API 写法

在 Vue 3 组合式 API 里,生命周期钩子变成了 onXxx() 形式:

<script setup>
import { onMounted, onUnmounted, ref } from "vue";

const message = ref("Hello Vue 3");

onMounted(() => {
  console.log("组件已挂载");
});

onUnmounted(() => {
  console.log("组件已卸载");
});
</script>

区别:

  • 直接使用 onMounted(),不需要 mounted()
  • 适用于 setup() 语法,更简洁。

watchEffect 替代 mounted + watch

Vue 2 中,通常需要在 mounted()watch 监听数据:

<script>
export default {
  data() {
    return {
      count: 0
    };
  },
  mounted() {
    this.$watch("count", (newValue, oldValue) => {
      console.log("count 变化:", oldValue, "=>", newValue);
    });
  }
};
</script>

Vue 3 推荐用 watchEffect()

<script setup>
import { ref, watchEffect } from "vue";

const count = ref(0);

watchEffect(() => {
  console.log("count 变化:", count.value);
});
</script>

区别:

  • watchEffect() 会自动追踪 count.value,不需要手动指定。

推荐视频
https://www.bilibili.com/video/BV14g41117HB?spm_id_from=333.788.videopod.episodes&vd_source=036b64d827caa25b16f82980eccb482a&p=2

<think>好的,我现在要解决用户的问题:如何在Vue中将表单数据传到后端。首先,我需要明确用户的需求。他们可能正在开发一个Vue前端应用,需要将用户输入的表单数据发送到后端服务器,比如使用Node.js、Spring Boot或其他后端框架。用户可能对Vue的基本概念有所了解,但不确定如何实现数据的传输。 接下来,我需要回忆Vue中处理表单和数据传输的相关知识。首先,Vue通常通过v-model指令实现表单输入的双向数据绑定。然后,发送数据到后端通常使用axios库进行HTTP请求,或者原生的fetch API。用户可能需要知道如何安装axios,如何配置请求,以及如何处理响应和错误。 然后,我应该分步骤来组织回答。第一步是创建表单并绑定数据,这里需要解释v-model的使用,以及如何在Vue实例或组件中定义数据对象。第二步是处理表单提交,阻止默认的提交行为,使用@submit.prevent修饰符。第三步是发送HTTP请求,这里需要比较axios和fetch,给出两种方法的示例代码,并说明它们的区别。第四步是处理后端响应,展示如何处理成功和错误的情况。第五步是后端接收数据的示例,可能给出不同后端框架的代码片段,如Node.js/Express或Spring Boot。最后,可能需要提到跨域问题,提醒用户注意CORS配置。 同时,我需要确保回答的结构清晰,步骤明确,代码示例正确。比如,在代码示例中,要展示如何定义data()中的表单数据对象,如何在methods中定义submitForm方法,如何使用axios.post或fetch发送POST请求,以及如何处理响应。对于后端部分,可能需要简要说明如何接收JSON数据,但不需要深入后端的具体实现,因为问题主要关注前端部分。 可能还需要考虑用户的常见问题,例如表单验证。虽然用户没有明确提到,但可能在表单提交前需要进行验证,所以可以简要提到在submitForm方法中添加验证逻辑。另外,跨域问题也是一个常见障碍,应该提醒用户如果遇到跨域错误,需要检查后端的CORS设置。 需要确保回答使用中文,避免专业术语的过度使用,但必要时仍需要正确使用术语,如v-model、axios、POST请求等。同时,代码示例中的注释和变量名也应使用中文或英文,视情况而定,但保持一致性。 最后,检查是否有遗漏的步骤或可能的错误。例如,是否提到安装axios的步骤,是否在代码示例中正确使用了ES6的箭头函数,处理this上下文的问题。在Vue组件中,methods里的函数如果使用普通函数,this可能指向不正确,但使用箭头函数或正确绑定的话,应该没问题。不过,在示例中,通常使用普通函数,因为Vue自动绑定了methods的上下文。 总结思考过程后,组织成用户容易理解的步骤,每个步骤有明确的说明和示例代码,并确保覆盖从表单创建到后端接收的整个流程。同时,提醒注意事项,如CORS和表单验证,以帮助用户避免常见问题。</think>在Vue中向后台传递表单数据主要分为以下步骤,我们以最常见的`axios`库发送HTTP请求为例: --- ### 一、创建表单并绑定数据 ```vue <template> <form @submit.prevent="submitForm"> <input v-model="formData.username" type="text" placeholder="用户名"> <input v-model="formData.password" type="password" placeholder="密码"> <button type="submit">提交</button> </form> </template> <script> export default { data() { return { formData: { username: &#39;&#39;, password: &#39;&#39; } } } } </script> ``` - **`v-model`** 实现表单数据双向绑定 - **`@submit.prevent`** 阻止表单默认提交行为 --- ### 二、安装axios ```bash npm install axios # 或 yarn add axios ``` --- ### 三、发送HTTP请求 #### 方法1:使用axios ```vue <script> import axios from &#39;axios&#39;; export default { methods: { async submitForm() { try { const response = await axios.post(&#39;/api/login&#39;, this.formData); console.log(&#39;响应数据:&#39;, response.data); } catch (error) { console.error(&#39;请求失败:&#39;, error); } } } } </script> ``` #### 方法2:使用原生fetch ```vue <script> export default { methods: { async submitForm() { try { const response = await fetch(&#39;/api/login&#39;, { method: &#39;POST&#39;, headers: { &#39;Content-Type&#39;: &#39;application/json&#39; }, body: JSON.stringify(this.formData) }); const data = await response.json(); console.log(&#39;响应数据:&#39;, data); } catch (error) { console.error(&#39;请求失败:&#39;, error); } } } } </script> ``` --- ### 四、后端接收示例 #### Node.js/Express 示例: ```javascript app.post(&#39;/api/login&#39;, (req, res) => { const { username, password } = req.body; // 处理逻辑... res.json({ success: true }); }); ``` #### Spring Boot 示例: ```java @PostMapping("/api/login") public ResponseEntity<?> login(@RequestBody LoginForm form) { // form.getUsername() 和 form.getPassword() 获取数据 return ResponseEntity.ok().build(); } ``` --- ### 五、关键注意事项 1. **跨域问题(CORS)**:如果前后端不同源,需在后端配置CORS 2. **请求头设置**:确保设置`Content-Type: application/json` 3. **表单验证**:建议在提交前添加验证逻辑 ```javascript if (!this.formData.username || !this.formData.password) { alert(&#39;请填写完整信息&#39;); return; } ``` 通过以上步骤,即可完整实现从Vue表单到后端的数据传输流程。根据具体需求,可扩展文件上传、进度监控等高级功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值