vue3项目的创建、入口文件、全局方法、生命周期函数、setup中的生命周期函数使用、data的函数方式

news2025/1/17 8:50:18

文章目录

  • 1. 创建vue3项目
    • 1.1 基于webpack的工程创建
    • 1.2 通过vite来创建vue3项目
      • vue3插件推荐
    • 1.3 通过npm init vue@3创建项目
  • 2. vue3入口文件
  • 3. vue3中的全局方法修改
  • 4. vue3中封装全局方法
  • 5. vue3生命周期函数
  • 6. setup中生命周期使用
  • 7. data函数方式


1. 创建vue3项目

1.1 基于webpack的工程创建

在用这种方式创建vue3项目时,要注意以下几点:

  1. 确保你的vue-cli 脚手架版本在 4.5.0 以上,这样才能创建
  2. 检查脚手架版本 vue -V 或 vue --version
  3. 如果版本低话,请重新安装 vue-cli,使用命令为:npm install -g @vue/cli

创建流程:

  1. 在命令提示符输入vue create vue3-project

  2. 选择安装方式:

    在这里插入图片描述

  3. 选择安装的模块

    在这里插入图片描述

  4. 选择安装的vue版本

    在这里插入图片描述

  5. 路由的模式

    在这里插入图片描述

  6. ccs预处理

    在这里插入图片描述

  7. 配置文件的存储位置

    在这里插入图片描述

  8. 不保存创建项目的设置,到此项目创建成功

    在这里插入图片描述

1.2 通过vite来创建vue3项目

  1. 在命令提示符输入以下命令:yarn create vite myapp01_vite

    在这里插入图片描述

  2. 选中vue进行创建

    在这里插入图片描述

  3. 选择语言模式

    在这里插入图片描述

  4. 至此,项目创建完成,按提示运行项目

    在这里插入图片描述

最后,我们来看一下创建成功后的目录结构:

在这里插入图片描述

vue3插件推荐

在这里插入图片描述

在这里插入图片描述

1.3 通过npm init vue@3创建项目

使用create-vue来创建vue3项目,它也是基于vite来构建的

命令:

npm init vue@3

在这里插入图片描述

指定项目名称:
在这里插入图片描述

选择需要的配置:

在这里插入图片描述

2. vue3入口文件

vue3 的入口文件,相对于 vue2 做了一定改变:

// 创建vue入口程序,由原来的类实例,变成现在的函数方式,为了更好在打包时优化代码
import { createApp } from 'vue'
// 根组件
import App from './App.vue'

// 实例化一个Vue顶层组件
const app = createApp(App)
app.mount('#app')

在这里插入图片描述

3. vue3中的全局方法修改

vue2 中的全局方法都是添加在 Vue 类的静态方法或属性当中,而在 vue3 中,我们把全局方法都添加在了 app 实例当中。

2.x Global API3.x Instance API(app)
Vue.configapp.config
Vue.config.productionTip已移除
Vue.config.ignoredElementsapp.config.isCustomElement
Vue.componentapp.component
Vue.directiveapp.directive
Vue.mixinapp.mixin
Vue.useapp.use

示例:

入口文件(main.js):

// 创建vue入口程序,由原来的类实例,变成现在的函数方式,为了更好在打包时优化代码
import { createApp, h } from 'vue'
// 根组件
import App from './App.vue'

// 实例化一个Vue顶层组件
const app = createApp(App)

// vue3中把之前vue2中的全局方法进行了改变,全都迁移到app实例上
// 定义一个全局组件
app.component('loading', {
  render() {
    return h('h1', null, '加载中...')
  }
})

// 给vue添加全局的成员属性
app.config.globalProperties.$http = '我是网络请求对象'

// 全局自定义指令 v-red  
// 7个钩子函数:created beforeMount mounted beforeUpdate updated beforeUnmount unmounted
app.directive('red', {
  created(el) {
    el.style.cssText = 'color:red;'
  },
  // 删除app组件
  // mounted(el) {
  //   el.remove()
  // }
})

// 全局混入
app.mixin({
  data() {
    return {
      title: '我是全局混入'
    }
  },
  mounted() {
    console.log('全局混入 -- mounted');
  }
})

// 全局插件
app.use(instanceVue => {
  // console.log(instanceVue);
  instanceVue.component('test', {
    render() {
      return h('h3', null, '我是插件中定义的组件')
    }
  })
})

app.mount('#app')

App组件(App.vue):

<template>
  <div>
    <h3 v-red>App组件--{{  title  }}</h3>
    <!-- 全局组件 -->
    <loading />
    <test />
  </div>
</template>

<script>
export default {
  mounted() {
    console.log(this.$http, '组件内')
  }
}
</script>

<style lang="scss" scoped>

</style>

在这里插入图片描述

4. vue3中封装全局方法

入口文件(main.js):

// 创建vue入口程序,由原来的类实例,变成现在的函数方式,为了更好在打包时优化代码
import { createApp } from 'vue'
// 根组件
import App from './App.vue'

import createGlobalComponent from './components'
import globalProperties from './config/globalProperties'

// 实例化一个Vue顶层组件
const app = createApp(App)

// 创建全局组件
// createGlobalComponent(app)
app.use(createGlobalComponent)
app.use(globalProperties)

app.mount('#app')

App组件(App.vue):

<template>
  <div>
    <h3>App组件</h3>
    <loading />
    <test />
  </div>
</template>

<script>
export default {
  data() {
    return {}
  },
  mounted() {
    console.log(this.$http, '组件内')
  }
}
</script>

<style lang="scss" scoped></style>

commponents入口文件(index.js):

import loading from './loading'
import test from './test'

const createGlobalComponent = app => {
  loading(app)
  test(app)
}

export default createGlobalComponent

loading组件(index.js):

import loading from './loading.vue'

export default app => app.component('loading', loading)

loading组件(loading.vue):

<template>
  <div>
    <h3>加载中</h3>
  </div>
</template>

<script>
export default {
  setup() {
    return {}
  }
}
</script>

<style lang="scss" scoped>
h3 {
  color: red;
}
</style>

test组件同loading组件代码基本一致,这里省略。

全局成员属性配置文件(config/globalProperties.js):

export default app => {
  // 给vue添加全局的成员属性
  app.config.globalProperties.$http = '我是网络请求对象'
}

运行结果:

在这里插入图片描述

5. vue3生命周期函数

在这里插入图片描述

执行顺序:

在这里插入图片描述

6. setup中生命周期使用

<template>
  <div>
    <h3>App组件</h3>
  </div>
</template>

<script>
import { onMounted } from 'vue'
export default {
  // setup 配置选项出现,为了照顾vue2,又想使用vue3
  // setup它就是组合Api的入口
  // setup中,它不能使用this,它里面没有 beforeCreate和created生命周期
  // 返回值 {} | ()=>{}
  setup() {
    // setup中的生命周期能执行多次
    onMounted(() => {
      console.log('我是一个mounted生命周期')
    })
    onMounted(() => {
      console.log('我是一个mounted生命周期')
    })
    onMounted(() => {
      console.log('我是一个mounted生命周期')
    })
    onMounted(() => {
      console.log('我是一个mounted生命周期')
    })

    return {}
  },
  // 这个生命周期只能执行一次
  // mounted(){
  //   console.log('aaa');
  // }
}
</script>

<style lang="scss" scoped>

</style>

在这里插入图片描述

由于组合API(setup())中生命周期钩子函数能够执行多次,所以我们可以使用自定义钩子,实现不同的功能。

注意:setup中,它不能使用this,它里面没有 beforeCreate和created生命周期。

我们可以创建一个 hooks 文件,用来存储,我们自定义的钩子函数,例如下面这个函数:

usePrintHook.js:

import { onMounted } from 'vue';

const usePrintHook = () => {
  // 在挂载完成后,输出一句话
  // 初始化时,进行网络请求
  // 挂载完成后,进行dom操作 
  onMounted(() => {
    console.log('我是一个mounted生命周期')
  })
  // 可以书写返回值
  return 'abc'
}
export default usePrintHook

App组件(App.vue):

<template>
  <div>
    <h3>App组件</h3>
  </div>
</template>

<script>
import usePrintHook from './hooks/usePrintHook'
export default {
  setup() {
    let ret = usePrintHook()

    return {}
  }
}
</script>

<style lang="scss" scoped>

</style>

7. data函数方式

data 只能定义成一个函数,例如下面这样:

<template>
  <div>
    <h3>{{ count }}</h3>
    <button @click="handleAddClick">add</button>
  </div>
</template>

<script>
import _ from 'lodash'
export default {
  // vue3中的data属性,要求全都为函数且返回一个对象
  data() {
    return {
      count: 100
    }
  },
  // 它是一个方法,每次来获取都是新,复用时,不会受到相互的影响,对于性能是一种提升
  created() {
    // this.handleAddClick = () => this.count++
    this.handleAddClick = _.debounce(() => this.count++, 100)
  },
  methods: {
    // 这种方法对于可复用组件有潜在的问题,因为它们都共享相同的防抖函数。
    // 为了使组件实例彼此独立,可以在生命周期钩子的 created 里添加该防抖函数
    // handleAddClick() {
    //   this.count++
    // }
  }
}
</script>

<style lang="scss" scoped></style>

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/23855.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot中消息是什么?同步异步消息是啥/都包含那些技术?Activate MQ消息怎么整合

写在前面&#xff1a; 继续记录自己的SpringBoot学习之旅&#xff0c;这次是SpringBoot应用相关知识学习记录。若看不懂则建议先看前几篇博客&#xff0c;详细代码可在我的Gitee仓库SpringBoot克隆下载学习使用&#xff01; 3.5.4 消息 3.5.4.1 简述 消息发送方&#xff1a;…

力扣(LeetCode)29. 两数相除(C++)

快速乘 题解只使用了 intintint 。 万恶的 INT_MININT\_MININT_MIN&#xff0c;怎么处理&#xff1f;打不过就加入——被除数和除数转为负数计算 。 xxx 除以 yyy &#xff0c;等于从 xxx 中拿出若干个 yyy 。 从 xxx 中拿出 yyy 的数量&#xff0c;就是 xyx\div yxy 的商。 y…

Allegro差分自动添加回流地孔操作指导

Allegro差分自动添加回流地孔操作指导 Allegro自带给差分添加回流地孔的功能,具体操作如下 点击connect命令,任意拉一对差分 鼠标右击,选择Return Path。。。,选择settings 会弹出设置的对话框,Assign net name给孔分配一个网络,一般是GND, Return Path via 选择添加…

2019年1+X 证书 Web 前端开发中级理论考试题目原题+答案——第五套

&#x1f4da;文章目录 &#x1f3af;关于1X标准 &#x1f3af;关于中级考点 ⏩&#x1f4bb;答案速查 理论题(满分100分)&#xff0c;包括单选题、多选题、判断题。 &#x1f4d1;一、单选题&#xff08;每小题2分&#xff0c;共30小题&#xff0c;共60分&#xff09; &…

Docker的基础命令

1.查找可用的镜像 docker search 镜像名 例&#xff1a;docker search nginxdocker search mysql2.拉取官方镜像&#xff08;及下载镜像&#xff09; docker pull 镜像名:标签例&#xff1a;docker pull nginx #表示现在最新版本的nginx镜像docker pull nginx:1.14…

使用frida发送微信消息给好友

前言 之前说过怎么用python来发送微信文本消息&#xff0c;原理大概就是构造内存机器码。其实frida也可以做类似操作&#xff0c;构造数据和机器码&#xff0c;然后调用。我就不重复操作了&#xff0c;这里说下另一种方法。 想使用frida来发送消息这个想法很早之前就有了&…

SQLlite

SQLlite ​ SQLite是一个软件库&#xff0c;实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。 一、什么是 SQLite ​ SQLite是一个进程内的库&#xff0c;实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库&…

Webpack 5 超详细解读(三)

21.babel-loader 使用 使用babel-loader对js文件进行处理&#xff0c;在lg.Webpack.js配置文件中配置js文件规则。 使用单独的插件进行转换 使用预设进行转换 使用babel.config.js配置文件进行babel配置 const path require(path) const CopyWebpackPlugin require(copy-W…

解决哈希冲突的方案

什么是哈希表 一种实现关联数组抽象数据类型的数据结构&#xff0c;这种结构可以将关键码映射到给定值。简单来说哈希表&#xff08;key-value&#xff09;之间存在一个映射关系&#xff0c;是键值对的关系&#xff0c;一个键对应一个值。 什么是哈希冲突 当两个不同的数经过…

基于 Text-CNN 的情感分析(文本分类)----概念与应用

文章目录基于Text-CNN情感分析卷积的基本概念Text-CNN的核心思想实现数据预处理批量处理操作--填充与截断拆分训练集与测试集定义Text-CNN模型设计模型定义与训练参数训练并评估模型结语基于Text-CNN情感分析 大家都知道&#xff0c;CNN(Convolutional Neural Network) 是深度…

非近轴衍射分束器的设计与严格分析

摘要 直接设计非近轴衍射分束器仍然是很困难的。由于有相对较大的分束角&#xff0c;元件的特征尺寸一般等于或小于工作波长。因此&#xff0c;它通常超出近轴建模方法的范围。在此示例中&#xff0c;将迭代傅里叶变换算法&#xff08;IFTA&#xff09;和薄元件近似&#xff08…

在线的MySQL数据库表结构对比工具

在项目部署上线前&#xff0c;测试版和正式版的数据库表结构做过哪些变更&#xff0c;如果没有做好实时记录&#xff0c;那么就需要对比找出差异&#xff0c;否则代码部分更新后&#xff0c;可能导致功能异常。 数据库表结构对比的工具很多&#xff0c;但是为了方便部署同步的…

Python 算法:线性回归及相关公式推导

0 前言 本文以一个小小的案例展开&#xff0c;主要讲解了线性回归的步骤、常用的两种求最优解的方法&#xff08;最小二乘法和sklearn回归算法及算法原理&#xff09;及相关函数、公式的过程推导。 相关环境&#xff1a;Windows 64位 Python3.9 scikit-learn1.0.2pandas1.4.2…

怎么在VMware上安装Linux?

推荐教程&#xff1a;Linux零基础快速入门到精通 下载CentOS操作系统 首先&#xff0c;我们需要下载操作系统的安装文件&#xff0c;本次使用CentOS7.6版本进行学习&#xff1a; https://vault.centos.org/7.6.1810/isos/x86_64/ (最后的/不要漏掉&#xff09; •或者直接…

02、Spring中的Bean实例化、作用域、生命周期及装配方式介绍

简介&#xff1a;本笔记主要介绍以下几点 1、Bean的常见属性及其子元素 2、实例化Bean的三种方式 3、Bean的生命周期和作用域 4、Bean的三种装配方式 1、Bean的配置 Spring简单来说就是一个大工厂&#xff0c;这个工厂负责创建和管理Spring容器中的Bean对象&#xff0c;如果要使…

基于深度学习的人脸表情识别的AR川剧变脸(一)

1、摘要 本项目分为两部分&#xff0c;第一个部分是人脸表情识别任务&#xff0c;第二部分是根据表情变化不同AR脸谱效果。 本文将第一部分&#xff0c;如何使用Keras训练一个人脸表情识别的卷积神经网络。 2、数据集处理 数据集我们使用FER2013PLUS人脸表情识别数据集&…

Spring Boot如何进行监控项目/SpringBoot Admin监控程序怎么用/监控程序可以监控到哪些信息

写在前面&#xff1a; 继续记录自己的SpringBoot学习之旅&#xff0c;这次是SpringBoot应用相关知识学习记录。若看不懂则建议先看前几篇博客&#xff0c;详细代码可在我的Gitee仓库SpringBoot克隆下载学习使用&#xff01; 3.6 监控 3.6.1 意义 监控服务是否宕机监控服务运…

Hive数据定义语言-DDL-入门基础(含四个实践案例)

1. 概述 数据定义语言DDL&#xff0c;是SQL语言集中对数据库内部的对象结构进行创建、删除、修改等的操作语言&#xff0c;这些数据库对象包括database、table、view、index等。DDL核心语法由CREATE、ALTER与DROP三个所组成。DDL并不涉及表内部数据的操作。在某些上下文中&…

Docker ENV 与 ARG 详解

Docker Env 与 ARG 详解 Env 与ARG 差异可以用下面一张图来表示 ENV 使用说明 ENV 变量只能在容器运行时&#xff0c;生效 如果想在执行命令的时候&#xff0c;使用ENV变量需要在shell 模式下采用生效&#xff0c;比如我们运行spring boot 应用, 其中JAVA_OPTS 变量通过doc…

德国跨国汽车巨头大陆集团遭LockBit勒索软件组织攻击

据BleepingCompuer11月3日消息&#xff0c;知名勒索软件组织LockBit宣布他们对德国跨国汽车集团大陆集团&#xff08; Continental&#xff09; 发动了网络攻击。 LockBit声称&#xff0c;他们窃取了大陆集团系统中的一些数据&#xff0c;如果不能在11 月 4 日 15:45:36&#x…