vue3 知识

vue3介绍

Vue3的变化:
    1、vue3完全兼容vue2,但是vue3不建议用vue2的写法
    2、拥抱TypeScript,ts完全兼容js
    3、组合式API和配置项API
                vue2 是配置项api
                vue3 组合式api

vue3项目创建和启动

# 创建vue3项目:
            vue-cli   官方不太建议用了
            vite      目前官方推荐:新一代前端构建工具

# vue-cli创建:
        命令行中:vue create vue3_demo001
        其他跟之前一样,只是选vue版本选3版本

# vue3的项目简单解释:

// main.js
import { createApp } from 'vue'  // 通过 createApp创建vue实例
import App from './App.vue'  // 根组件
import router from './router' // vue-router
import store from './store' // vuex

var vue = createApp(App) // 创建vue实例
vue.use(store)// 使用vuex
vue.use(router)// 使用vue-router
vue.mount('#app')// 挂在index.html中得div

# 其他写起来跟之前写vue2完全一致,vue3是兼容的

# vite创建vue3(速度快)
    不管是创建项目还是运行项目速度都很快,因为它按需编译,不再等待整个应用编译完成

cnpm create vite vue3_demo002  //创建项目
    
cnpm install  // 打开项目,安装依赖
    
npm run dev   // 运行项目

# 使用vite和vue3创建项目的文件简单解释:

// main.js    
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
createApp(App).mount('#app') # 没有使用第三方插件
// HelloWorld.vue   组合式api写法,跟之前不一样了
<script setup>
import { ref } from 'vue'
defineProps({
    msg: String,
})
const count = ref(0)
</script>
<template>
    <h1>{{ msg }}</h1>
    <div class="card">
        <button type="button" @click="count++">count is {{ count }}</button>
    </div>
</template>

# 实现:创建vue2一样,自由选择一些插件, 在vue3上,建议使用 pinia 做状态管理

# 常用的第三方插件,自己选即可:

                        npm create vue@latest    

setup函数

# vue3_demo001 :vue-cli创建的---写法跟之前vue2一样
   vue3_demo002 :vite创建,但是没有状态管理器和路由
   vue3_demo003:vite创建,有状态管理器和路由

# setup 函数,只有vue3中有:
            setup为Vue3.0中一个新的配置项,值为一个函数
            setup是所有Composition API(组合API)编写的位置
            组件中所用到的:数据、方法等等,均要配置在setup中
    setup函数的返回值:返回一个对象,对象中的属性、方法, 在模板中均可以直接使用
# 注意
    1、尽量不要与Vue2.x配置混用
    2、Vue2.x配置(data、methos、computed...)中可以访问到setup中的属性、方法
    3、但在setup中不能访问到Vue2.x配置(data、methos、computed...)。
    4、如果有重名, setup优先

<template>
  <div class="home">
    <h1>setup函数的使用</h1>
    {{ name }}--{{ age }}
    <button @click="add">点我年龄+1</button>
  </div>
</template>

<script>
import HelloWorld from '@/components/HelloWorld.vue'

export default {
  name: 'HomeView',
  setup() {
    let age = 19
    let add = () => {
      // 默认不是响应式的
      age++
    }
    return {name, age, add}
  },
}
</script>

vue3之ref

# 1、ref 用来做 基础变量 [数字,字符串,布尔] 的响应式
         reactive 用来做对象 [数组,字典] 的响应式

<script>
import { ref,reactive } from "vue";
export default {
  name: 'HomeView',
  setup(){
    let name = ref('zjq')
    let age = ref('21')
    let add = () => {
      age.value++
      console.log(age.value)
    }
    let handleChange = (newname) => {
      name.value = newname
    }
    return {name,age,add,handleChange}
  }}
</script>

# 2、在子组件中暴露

<script setup>
    import {ref, reactive,} from "vue";
    const helloworld = ref()   // 变量名必须跟 在组件上定义的名字一致
    function handleClick() {
          console.log(helloworld.value) // helloworld.value拿到组件对象
          // 使用组件对象的属性和方法,需要子组件暴露---》只能用子组件暴露的
          helloworld.value.add()
          console.log(helloworld.value.person.name)}
</script>

<template>
  <HelloWorld ref="helloworld"></HelloWorld>
  <button @click="handleClick">点我看控制台</button>  
</template>

vue3之toRefs

响应式

        toRefs 可以把对象内部的所有值,都做成响应式
        改这些变量会影响到原来对象中得值

const person = reactive({name: 'lqz', age: 19})
let {name, age:nl} = toRefs(person)  // 等同于: name=ref(lqz)   age=ref(19)
// let {name, age} = person  // 等同于: name=lqz   age=19
function add() {
  nl.value++
  console.log(nl.value)
}

# 结构赋值

let person = {name: 'lqz', age: 19}
let {name, age} = person //  普通解构赋值,name=person.name   age=person.age
let {name:a, age} = person // 重命名解构赋值:a=person.name   age=person.age
console.log(a)
console.log(age)

# 对象解压

<script>
import {toRefs, reactive,} from 'vue'
export default {
  name: 'HomeView',
  setup() {
    let data = reactive({
      name: 'lqz',
      age: 19,
      hobby: '篮球'
    })
    let xx = {...toRefs(data)}  // {name:lqz,age:19,bobby:篮球}
    // 可以把对象解压
    return {...toRefs(data), count}   // {name:lqz,age:19,bobby:篮球,count:0}
  },}
</script>

toRef的使用:

const person = reactive({name: 'lqz', age: 19})
// const name=toRefs(person)  //{name:ref(name),age:ref(age)}
const name = toRef(person, 'name')  //name=ref(person.name)
function change() {
  name.value = 'xxx'
}

vue3之reactive

<template>
  <div class="home">
    <h1>setup函数的使用</h1>
    <p>用户名:{{ userInfo.name }}</p>
    <p>年龄:{{ userInfo.age }}</p>
    <p>爱好:{{ userInfo.hobby }}</p>
    <button @click="handleAdd">点我年龄+1</button>
  </div>
</template>

<script>
import {ref, reactive} from 'vue'

export default {
  name: 'HomeView',
  setup() {
    let userInfo = reactive({
      name: 'lqz',
      age: 19,
      hobby: '篮球'
    })
    let handleAdd = () => {
      userInfo.age++
      console.log(userInfo)
    }
    return {userInfo, handleAdd}
  },
}
</script>

# ref和reactive总结:

 ref函数:
    作用: 定义一个响应式的数据
    语法: let xxx = ref(initValue)
    创建一个包含响应式数据的引用对象(reference对象,简称ref对象)。
    JS中操作数据: xxx.value
    模板中读取数据: 不需要.value,直接:<div>{{xxx}}</div>
reactive函数:
    作用: 定义一个对象类型的响应式数据(基本类型不要用它,要用ref函数)
    语法:let 代理对象= reactive(接收一个对象,返回一个代理对象
    reactive定义的响应式数据是“深层次的”,对象无论多少层,都可以

vue3之axio

# 安装:

cnpm install axios

# 在 setup 中直接发送请求

import axios from 'axios'
const filmList = reactive({result:[]})
axios.get('http://127.0.0.1:8000/film/').then(res => {
  console.log(res.data)
  filmList.result = res.data.results
})

# async await 的使用

const filmList = reactive({result: []})
async function load() {
  // await必须写在被async修饰的函数中,也可以写在setup函数中
  let response = await axios.get('http://127.0.0.1:8000/film/')
  filmList.result = response.data.results
}
load()

# axios 的拦截器
    请求发出之前的拦截器
    请求响应回来的拦截器
        判断状态码是不是100,如果是100,继续走,不是100,直接弹错误

计算属性computed

  let person=reactive({name:lqz,age:19})
    # 1 只取值
    person.hobby=computed(()=>{
      return person.name+person.age
    })
    # 2 取值和赋值
    person.hobby=computed({
      get(){
        return 'xxxx'
      },
      set(newValue){
      }
    })

<template>
  <div class="home">
    <h1>计算属性:computed</h1>
    <p>姓:<input type="text" v-model="person.firstName"></p>
    <p>名:<input type="text" v-model="person.lastName"></p>
    <p>全名:{{ person.fullName }}</p>
    <p>全名修改:<input type="text" v-model="person.fullName"></p>
  </div>
</template>

<script>
import {ref, reactive, computed} from 'vue'
export default {
  name: 'HomeView',
  setup() {
    let person = reactive({
      firstName: '',
      lastName: ''
    })
    // 计算属性---》修改值
    person.fullName = computed({
      get() {
        return person.firstName +person.lastName
      },
      set(newValue) {
        console.log(newValue)
        person.firstName=newValue.substring(0,1)
        person.lastName=newValue.slice(1)
      }
    })
    return {person}
  },
}
</script>

监听属性watch

<template>
  <div class="home">
    <h1>监听属性:watch</h1>
    {{ age }} ====
    <button @click="handleClick">点我+1</button>
    <hr>
    <p>用户名:{{ userInfo.name }}</p>
    <button @click="handleChange">点我变长名字</button>
  </div>
</template>

<script>
import {ref, reactive, watch, computed} from 'vue'

export default {
  name: 'HomeView',
  setup() {
    let age = ref(0)
    let handleClick = () => {
      age.value++
    }
    // 1 监听基本类型
    watch(age, (newValue, oldValue) => {
      console.log(oldValue)
      console.log(newValue)
    })
    // 2 监听对象
    let userInfo = reactive({
      name: 'zjq',
      age: 19
    })
    let handleChange = () => {
      userInfo.name = '谢谢谢谢谢寻寻寻寻'
    }
    watch(() => userInfo.name, (newValue, oldValue) => {
      console.log('名字变了:' + userInfo.name)
    })
    // 3 同时监听多个变量变化
     watch([age,], (newValue, oldValue) => {
      console.log('age或msg变化了', newValue, oldValue)
    })
    return {age, handleClick, userInfo, handleChange}
  },
}
</script>

生命周期

vue2 : 8个生命周期钩子
      beforeCreate:组件创建之前实现这个:组件html,js--》html和js都是空的
      created:组件创建完成后:js就有值了,html还是空的  (向后端发送ajax请求)
      beforeMount:挂载模板之前,js有值,模板(html) 还是空的(向后端发送ajax请求)
      mounted:挂载完成:js有值,模板有值
      beforeUpdate:只要页面发送变化或js变量发生变化,就会触发它的执行
      updated:刷新之后执行
      beforeDestroy:被销毁之前执行  (资源清理性工作)
      destroyed:被销毁之后执行
vue3 中变成:
    beforeDestroy改名为 beforeUnmount
    destroyed改名为 unmounted
 Vue3.0也提供了 Composition API 形式的生命周期钩子,与Vue2.x中钩子对应关系如下:
        beforeCreate===>setup()
        created=======>setup()
        beforeMount ===>onBeforeMount
        mounted=======>onMounted
        beforeUpdate===>onBeforeUpdate
        updated =======>onUpdated
        beforeDestroy==>onBeforeUnmount
        destroyed=====>onUnmounted

<template>
  <div class="home">
    <h1>生命周期</h1>
    {{ name }}
    <br>
    <button @click="handleClick">点我变名字</button>
  </div>
</template>

<script>
import {ref,reactive,watch,computed,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted} from 'vue'
import axios from 'axios'

export default {
  name: 'HomeView',
  setup() {
    //1 这里写的代码,就是 beforeCreate,没有数据[变量没定义],没挂载
    console.log('beforeCreate')
    // 2 这里写代码,就是created,有数据,变量定义了,没挂载
    let name = ref('lqz')
    axios.get('http://127.0.0.1:8000/film/').then(res => {
      name.value = res.data.msg
    })
    // 3 onMounted
    onMounted(() => {
      console.log('挂载完了')
    })
    // 4 onUpdated
    onUpdated(() => {
      console.log('页面更新')
    })
    // 5 onUnmounted
    onUnmounted(() => {
      console.log('组件销毁')
    })
    let handleClick = () => {
      name.value = 'afdasdfasdfasdf'
    }
    return {name, handleClick}
  },}
</script>

setup写法

# 以后都使用组合式api
# 典型写法:
        <script setup lang="js" name="组件名字">
        </script>

不需要return,它会自动return
如果注册局部组件,只需要导入组件即可,在template中就可以使用了
# 以后只需要在 setup 内,写变量,写函数即可

    const age=ref(0)
    function add(){
      age.value++
    }

# vue-router的使用
路由跳转:

    import {useRouter, useRoute} from 'vue-router'
    const router = useRouter() // 就是以前的this.$router
    const route = useRoute()  // 就是以前的this.$route

路由注册---跟之前一模一样
路由的api---跟之前一样:
            router.push({name:'home'})

路由嵌套,跟之前一样

路由守卫跟之前一样:
                router.beforeEach()

<template>
  <h1>我是首页</h1>
    <div>{{ name }}</div>
    <button @click="handleChange">点我变名字</button>

    <button @click="load">点我加载</button>
    <div v-for="film in filmList">
    <p>{{ film.name }}</p>

    </div>

    <HelloWorld msg="lqz is handsome"></HelloWorld>
    <RouterLink to="/about"><button>点我跳转到about</button></RouterLink>
    <button @click="handleGo">点我跳转到about</button>

  {{ store.count }}
  <button @click="handleAdd">点击+1</button>
</template>

<script setup lang="js">
//1  以后这里面写的,就相当于 写在setup函数中,现在不需要返回,在template都能用到
import {ref,reactive} from 'vue'
let name = ref('lqz')
let handleChange = () => {
  name.value = 'sadfasdfafs'
  console.log(name)
}


// 2  加载电影数据
import {ref, reactive} from 'vue'
import axios from 'axios'

let filmList = reactive([])
//发送ajax
let load = () => {
  axios.get('http://127.0.0.1:8000/film/').then(res => {
    filmList = res.data.results
    console.log(filmList)
  })
}


// 3 注册组件
import HelloWorld from '@/components/HelloWorld.vue'


// 4 路由跳转  setup中没有this了---》想用谁,就是导入谁
this.$router.push()  // 用不了了
import {useRouter, useRoute} from 'vue-router'
const router = useRouter()
const route = useRoute()

let handleGo = () => {
  router.push('/about?name=lqz')
}
</script>

pinia和elementui-plus

# 之前用vuex,vue3上还可以用,但是使用 pinia 更好

import {useCounterStore} from '@/stores/counter'
const store = useCounterStore()
console.log(store.count)

# elementui-plus

npm install element-plus --save
// main.js中:
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
app.use(ElementPlus)

登录练习

使用setup写法
elmentui 登录 显示电影
没登录不允许访问首页--->重定向到登录

今日思维导图: 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++创建窗口程序

实现一个基本的 Windows 应用程序&#xff0c;使用 C 和 WinAPI&#xff08;Windows API&#xff09;编写。运行这段代码时&#xff0c;它将显示一个标题为“Hello World”的窗口&#xff0c;并且可以通过关闭窗口来结束程序。 #include <windows.h> // 包含Windows头文…

【Python3】【力扣题】389. 找不同

【力扣题】题目描述&#xff1a; 【Python3】代码&#xff1a; 1、解题思路&#xff1a;使用计数器分别统计字符串中的元素和出现次数&#xff0c;两个计数器相减&#xff0c;结果就是新添加的元素。 知识点&#xff1a;collections.Counter(...)&#xff1a;字典子类&#x…

ONLYOFFICE:开源、免费、安全,打造定制化办公平台的最佳选择

文章目录 写在前面ONLYOFFICE是什么&#xff1f;ONLYOFFICE的惊艳之处齐全的插件&#xff0c;助你锦上添花部署一款自己的安全可靠的办公平台写在最后 写在前面 说起 Office 办公软件&#xff0c;我想大家最常用的应该就是微软的 Microsoft Office 以及国产的 WPS Office。两款…

C语言:进制转换以及原码、反码、补码

一、二进制 其实我们经常能听到2进制、8进制、10进制、16进制这样的讲法&#xff0c;那是什么意思呢&#xff1f;其实2进制、8进制、10进制、16进制是数值的不同表⽰形式⽽已。 比如&#xff1a; 数值15的各种进制的表⽰形式&#xff1a; 15的2进制&#xff1a;1111 15的8进…

HBuilder X中uView UI框架的安装及使用

开发工具: HBuilder X 在最上方的工具中点击 插件安装 ——> 安装新插件 ——> 前往插件市场安装 在作者排行榜中找到 uView UI 选择该版本 然后点击下载并导入HBuilder X 然后选择你想导入的项目 在项目根目录中的main.js中&#xff0c;引入并使用uView的JS库&#xff…

Java基础面试题(五)

Java基础面试题&#xff08;五&#xff09; 文章目录 Java基础面试题&#xff08;五&#xff09;标识符和关键字的区别是什么&#xff1f;Java 语言关键字有哪些&#xff1f;自增自减运算符移位运算符continue、break 和 return 的区别是什么&#xff1f; 单行注释&#xff1a;…

【软件设计】基于SSM的334考研图书电子商务平台

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

msvcr120.dll找不到要怎么处理?电脑文件msvcr120.dll修复攻略

在使用基于Windows操作系统的计算机的日常过程中&#xff0c;用户可能会遇到多种程序错误&#xff0c;其中之一就是“找不到msvcr120.dll”或者“msvcr120.dll丢失”的系统提示。这个问题往往在启动某些程序时发生&#xff0c;很让人无可奈何。为了解决这个问题&#xff0c;重要…

【Linux系统编程】环境变量的组织方式

environ和getenv函数 在Linux中&#xff0c;environ是一个全局的外部变量&#xff0c;其类型为char**&#xff0c;存储着系统的环境变量。除了使用主函数中的第三个参数外&#xff0c;我们也可使用environ函数直接访问系统的环境变量。 注意&#xff1a;这里在代码内部使用envi…

Spring Boot多环境配置

Spring Boot的针对不同的环境创建不同的配置文件&#xff0c; 语法结构&#xff1a;application-{profile}.properties profile:代表的就是一套环境 1.需求 application-dev.yml 开发环境 端口8090 application-test.yml 测试环境 端口8091 application-pro…

如何给新华网投稿发稿?新华网的媒体发稿方法步骤

现如今&#xff0c;互联网已经成为了人们获取信息的主要途径&#xff0c;各大媒体网站也成为了发布自己作品的首选平台。其中&#xff0c;新华网作为中国最具影响力的新闻媒体之一&#xff0c;其内容覆盖面广、触及人群众多&#xff0c;因此&#xff0c;能够在新华网上发表文章…

Tuxera NTFS2024下载使用详细操作教程

你是否还在为Mac不能正常读写NTFS格式分区而感到苦恼呢&#xff1f;想要适合Mac系统使用来回转换磁盘格式又十分麻烦&#xff0c;这该怎么办呢&#xff0c;有了这款软件Tuxera ntfs就能马上帮你解决目前遇到的问题。 Tuxera NTFS2024最新免费版下载如下&#xff1a; https://…

htb monitored root方式其中的一种(仅作记录)

快下班时候审出来的&#xff0c;目前root的第5种方式 nagiosmonitored:~$ cat /usr/local/nagiosxi/scripts/backup_xi.sh #!/bin/bash # # Creates a Full Backup of Nagios XI # Copyright (c) 2011-2020 Nagios Enterprises, LLC. All rights reserved. #BASEDIR$(dirname …

CentOS使用docker本地部署StackEdit Markdown编辑器并实现公网访问

文章目录 1. docker部署Stackedit2. 本地访问3. Linux 安装cpolar4. 配置Stackedit公网访问地址5. 公网远程访问Stackedit6. 固定Stackedit公网地址 StackEdit是一个受欢迎的Markdown编辑器&#xff0c;在GitHub上拥有20.7k Star&#xff01;&#xff0c;它支持将Markdown笔记保…

Linux:软硬链接的概念与应用

文章目录 软链接和硬链接软链接的应用场景硬链接的应用场景当前目录和上级目录总结 本篇要探讨的主题是关于软硬链接的概念 在Linux系统链接文件中有两种&#xff0c;一种是硬链接&#xff0c;一种是软链接&#xff0c;那么本篇就基于上述的两种链接方式来进行一定的总结和拓展…

IOS-UIAlertController简单使用-Swift

UIAlertControlle时IOS的对话框控制器&#xff08;警报控制器&#xff09;&#xff0c;简单使用方法如下&#xff1a; 步骤都一样&#xff0c;先是创建UIAlertController&#xff0c;然后创建UIAlertAction&#xff0c;再将UIAlertAction添加到UIAlertController中&#xff0c;…

Keil 的安装

Keil的安装&#xff0c;分3个主要步骤&#xff1a; ① 安装Keil软件 ② 注册 ③ 安装芯片支持包 一、安装 Keil 重点 1&#xff1a; 安装时&#xff0c;不能使用中文路径&#xff0c;否则无法正常使用!! 重点 2&#xff1a; 不要安装 V5.36 及以上的版本&#xff0c…

Qt SDL2播放Wav音频

这里介绍两种方法来实现Qt播放Wav音频数据。 方法一&#xff1a;使用QAudioOutput pro文件中加入multimedia模块。 #include <QApplication> #include <QFile> #include <QAudioFormat> #include <QAudioOutput>int main(int argc, char *argv[]) {…

游卡:OceanBase在游戏核心业务的规模化降本实践

从 2023 年 9 月测试 OceanBase&#xff0c;到如今 3 个核心业务应用 OceanBase&#xff0c;国内最早卡牌游戏研发者之一的游卡仅用了两个月。是什么原因让游卡放弃游戏行业通用的 MySQL方案&#xff0c;选择升级至 OceanBase&#xff1f;杭州游卡网络技术有限公司&#xff08;…

精品IDEA插件推荐:Apipost-Helper

Apipost-Helper是由Apipost推出的IDEA插件&#xff0c;写完接口可以进行快速调试&#xff0c;且支持搜索接口、根据method跳转接口&#xff0c;还支持生成标准的API文档&#xff0c;注意&#xff1a;这些操作都可以在代码编辑器内独立完成&#xff0c;非常好用&#xff01;这里…