当前位置: 首页 > wzjs >正文

做网站服务器 自己电脑还是租装修案例文案怎么写

做网站服务器 自己电脑还是租,装修案例文案怎么写,网站建设电脑端手机端,网络营销网站策划隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习Vue3的…

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

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

这里写目录标题

  • 一、Composition API
    • Vue 2 (Options API)
    • Vue 3 (Composition API)
  • 二、router
    • 创建 Router 实例的方式变化
      • Vue 2 (Vue Router 3)
      • Vue 3 (Vue Router 4)
    • 获取路由对象的方式
      • Vue 2
      • Vue 3
    • 动态路由的变化
      • Vue 2
      • Vue 3
  • 三、 全局变量和方法
    • 全局变量的定义
      • Vue 2:使用 Vue.prototype
      • Vue 3:使用 app.config.globalProperties
    • 全局方法的定义
      • Vue 2:使用 Vue.prototype
      • Vue 3:使用 globalProperties
  • 四、生命周期
    • 生命周期对比表
    • Options API 写法(Vue 3 仍支持 Vue 2 语法)
    • **Composition API 写法**
    • `watchEffect` 替代 `mounted + watch`

一、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

http://www.dtcms.com/wzjs/801228.html

相关文章:

  • 南通电商网站建设广东建设工程信息网站6
  • 给我免费观看片在线seo标题优化步骤
  • 深圳罗湖医疗集团网站建设苏州自助模板建站
  • 做视频资源网站陕西做网站的公司在哪
  • 绍兴网站seowordpress5.0
  • 网站空间哪家做的好天津实体店网站建设
  • 做网站前台用什么文学投稿网站平台建设
  • 智鼎互联网站建设网站只做程序员
  • 佛山网站建设企业报价成都品牌建设网站公司
  • 公司内部交流 网站模板电子商务网站开发期末考试
  • 郑州市制作网站的公司苏州保洁公司收费价格表
  • 哈尔滨网站建设哪家好wordpress电影站主题
  • 微信网站打不开爱主题wordpress
  • wordpress下载站用什么模板网页版百度云
  • 网站开发工资高吗手机网站app制作
  • 天津票网网站wordpress托管 安装
  • 营销单页模板网站怎么做汽车网站
  • 深圳网站设计公司yx成都柚米科技15如何给网站流量来源做标记通过在网址后边加问号?
  • 免费影视网站建设有个虚拟服务器建设网站
  • 校园网站的作用网页设计个人简历模板
  • 深圳网站建设设计网站首页设计方案
  • 建设银行的网站查询密码wordpress ftp
  • 手机网站模板 html5关键词工具网站
  • 少儿英语做游戏网站推荐网页制作与设计教案
  • 界面十分好看的网站微信小程序脚本
  • 新准则中公司网站建设费用计入什么科目wordpress 回到顶部
  • 湖南网站建设oqiandu豫建设标去哪个网站
  • 网站建设规划方案制作h5制作开发哪找
  • 深圳网站建设与设计制作自适应网站做推广
  • 徐州设计网站工程公司的会计做账有哪些科目