首页 > 其他分享 >vue3.x基本使用

vue3.x基本使用

时间:2023-02-22 21:45:13浏览次数:41  
标签:基本 vue name setup vue3 let 使用 ref

今日内容

vue3介绍

# 1 vue项目的版本 新项目使用vue3 有部分来项目使用2

# vue3的变化
    1.性能的提升
    	-打包大小减少41%
    	-初次渲染快55%, 更新渲染快133%
    	-内存减少54%
    2.源码的升级
    	使用Proxy代替defineProperty实现响应式
    	重写虚拟DOM的实现和Tree-Shaking
    3.拥抱TypeScript
    	Vue3可以更好的支持TypeScript
    4.新的特性
    	Composition API(组合API)
        setup配置
        ref与reactive
        watch与watchEffect
        provide与inject
        新的内置组件
        Fragment
        Teleport
        Suspense
        其他改变

        新的生命周期钩子
        data 选项应始终被声明为一个函数
        移除keyCode支持作为 v-on 的修饰符
        
   
# 组合式API和配置项
	vue2: 配置项API
        new Vue({
            el:'#app',
            data:{}
        })
    
    vue3: 组合式API
        let name='lqz'
        let add=()=>{}

vue3创建项目

1 使用vue-cil

# 与创建vue2是一样的 选中Vue3即可

2 vite

# 新建的前端构建工具 最大的优势就是速度快
	官网:
        https://cn.vuejs.org/guide/scaling-up/tooling.html#project-scaffolding
            
# 使用步骤
	-安装: npm init vue@latest
        -按需选择 vueRouter
    -cd到项目中执行 cnpm install(安装依赖)
    -运行: npm run dev
        
    -vueRouter:跟之前一样
 	-Pinia: 用来替换Vuex的 新一代的状态管理器
    -链式调用
    
# 快的原因:
	-创建项目快----> 不安装第三方依赖
 	-执行项目不再是热更新 而是按需编译

setup函数

# 把项目做成最简洁的

# vue2的创建vue实例和vue3创建vue实例的区别
	-new Vew()---> 是Vue的实例,里面有$store,$refs....
    -createApp(App)--->是个对象 对象里面有东西 没有 $store等 以后有用就需要导入使用
    
# 以后vue3 的<template> 不需要写一个标签

# 以后都写在setup函数中 定义变量 定义函数 一定要return 在templage才能使用

# 但是失去了响应式

export default {
  name: 'HelloWorld',
  setup(){
    let name ='cyf'
    let age = '99'
    return {name,age}
  }}
"""定义再setup中的可以是变量 方法 在根组件中可以直接使用 但是要return出来"""

ref和reactive

# 有响应式
	-以后定义变量 如果想有响应式就用 ref包裹起来 再修改变量 需要用 变量名.value 修改
    
# 配置项api和组合式api可以缩写 但是不建议
	-在前在data中定义的变量
 	-在setup中定义的变量
    
    -总结:
    	在setup中定义的变量和函数,在之前配置项api中可以直接使用this.变量,函数调用即可
    	但是在原来配置项中定义的变量,函数,在setup中无法使用
        
# 不同类型做响应式
	ref通常用来包裹 数字 字符串类型 以后使用 xx.value
    reactive用来包裹数组和对象类型 以后使用 直接用即可
 
# 总结
	ref定义的数据: 操作数据需要.value 读取数据时模板中直接读取不需要.value
	reactive定义的数据:操作数据与读取数据:均不需要.value (对象)

计算属性和监听属性

1 计算属性

# computed 的配置项中的写法 不建议使用
	computed:{
        fullName(){
            return this.firstName+this.lastName
        }
    }
   
# vue3新写法
	let userInfo = reactive({
        firstName:'',
        lastName:'',
    })
    let fullName = computed(()=>{
        return userInfo.firstName + userInfo.lastName
    })
	
# 计算属性取值和修改值
	let fullName = computed({
        get(){
            return userInfo.firstName + userInfo.lastName
        },
        set(args){
            userInfo.firstName = args.slice(0,1)
            userInfo.lastname = args.slice(1)
        }
    })

"""
computed 也是需要外部导入的
get对应的是 获取fullName的值时会触发
set对应的是 修改fullName的值就会触发
"""

2 监听属性

# 组合式api写法 只要name发生变化 就会触发匿名函数执行
	let name = ref('xiaochen')
    watch(name,(newName,oldName)=>{
        console.log('老的',oldName)
        console.log('新的',newName)
    })
    
"""
watch的三个参数对应的是 所监听的属性 变化后的属性 变化前的属性
(括号内的变量名可随意命名)
"""
# watchEffect 用法 只要age变化 就会执行 age不变化 就不会执行
	watchEffect(()=>{
        console.log(age.value)
    })
"""
只要是写在watchEffect里面的变量都会检测 只要发生变化就会执行
"""

生命周期

# vue3的变化,不推荐了
	-vue2       和    vue3比较
    beforeCreate===>beforeCreate
    created=======>created
    beforeMount ===>beforeMount
    mounted=======>mounted
    beforeUpdate===>beforeUpdate
    updated =======>updated
    beforeDestroy ==>beforeUnmount
    destroyed =====>unmounted
    
    
    
# 不推荐用这种写法了,配置项写法,统统写在setup中
    beforeCreate===>setup()
    created=======>setup()
    beforeMount ===>onBeforeMount
    mounted=======>onMounted
    beforeUpdate===>onBeforeUpdate
    updated =======>onUpdated
    beforeUnmount ==>onBeforeUnmount
    unmounted =====>onUnmounted
    
    
    
 # 以前写在created中的代码,现在直接写在setup开始即可
 let show = ref(false)
 axios.get().then(res=>{
      show.value=res.data.show
 })

toRefs

# 之后在setup的返回值可以直接使用
<template>
  <div class="about">
    <h1>This is an about page</h1>
    {{name}}
    {{age}}
  </div>
</template>

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

export default {
    name:'AboutView',
    setup(){
      let data = reactive({
      name: 'lqz',
      age: 19,
      gender: '男'
    })
    return {...toRefs(data)}
    }
  }
</script>

script setup的作用和lang=ts

# 以后 这个script中的代码会自动放到 setup函数中 不用return

# lang=ts
里面艾玛使用ts写(ts完全兼容js)
<script setup>
import {ref} from 'vue'
let name = ref('小陈')
let handleClick = () => {
  alert('美女')
}
</script>


<template>
  <div class="about">
    {{name}}
    <button @click="handleClick">点我看美女</button>
  </div>
</template>

vue后台管理模板

# 公司内部项目,会写后台管理,往上有很多vue开源的后台管理的框架,咱们只需要在上面做二次开发

# django-vue-admin 前端---》D2Admin 
# 若依:vue前端  用来   vue-element-admin
# elamin前端   drf  写了基于rbac权限管理的框架

# https://gitee.com/liuqingzheng/vue_admin

标签:基本,vue,name,setup,vue3,let,使用,ref
From: https://www.cnblogs.com/xiaochenxiangchangpang/p/17146070.html

相关文章

  • vue框架08 vue3
    vue3的介绍#vue项目的版本,新项目使用vue3,部分老项目使用vue2#vue3的变化1.性能的提升-打包大小减少41%-初次渲染快55%,更新渲染块133%......
  • vue_day08 vue3基本使用了解
    目录今日内容详细一、vue3介绍二、vue3创建项目1.使用vue-cli2.vite三、setup函数1.scriptsetup的作用和lang=ts四、ref和reactive五、计算属性和监听属性1.计算属性2.......
  • 解决Pillow在电脑终端中安装成功却无法在VScode中使用的问题
    系统:MacOS编辑器:VSCode环境:python3电脑终端安装因为没有安装过Pillow包,所以现在电脑终端中进行安装pipinstallpillow出现提示如下:搜索了网上的方法后,使用--tar......
  • Source Insight 4.0使用(一)
    已剪辑自:https://blog.csdn.net/weixin_46582567/article/details/124371330很多入门嵌入式的初学者所用的代码编写软件都是IAR、Keil等IDE(集成开发环境),这类软件的优......
  • 使用云服务器配置MariaDB环境,Navicat远程连接一直出错误代码 "2002 - Can't connect
    使用腾讯云或者阿里云的服务器配置MariaDB数据库环境的时候,用Navicat远程连接在Centos7的Linux上配置MariaDB数据库环境的时候一直出错误代码"2002-Can'tconnecttos......
  • vue3介绍 vue3创建项目 扩展vite setup函数 ref和reactive 计算属性和监听属性 生命周
    目录回顾vue3介绍vue的变化组合式API与配置项APIvue3创建项目扩展之vite使用步骤setup函数ref和reactiverefreative总结:计算属性和监听属性计算属性获取get 修改set监听属......
  • 数据挖掘基本概念
    数据挖掘定义值对数据进行收集,清洗,加工和分析并从中获取有用知识的过程。数据挖掘过程数据采集使用像传感器网络这样的专门硬件,手工录入的用户调查,或者如同Web爬虫工具......
  • LabVIEW|小技巧:Quick Drop(快速放置)的使用
      QuickDrop(快速放置)面板是LabVIEW的一个快速查找函数或者控件的选板,它提供一些快速查找函数的映射,在输入框内输入快捷映射或者名称,即可查找到对应的函数或控件。这个......
  • 使用golang和bluge打造自己的全文搜索引擎
    全文搜索引擎有许多,其中最出名的是elasticsearch,无论是性能还是体验都是最顶尖的,但是对小应用来不友好,因为小应用的硬件资源比较少,所以能够通过库/模块的方式内置在应用中......
  • Vue3
    目录Vue3vue3介绍vue3创建项目1.使用vue-cli创建2.vite创建vue项目setup函数1.setup函数2.vue2的创建vue实例和vue3创建vue实例的区别ref和reactivecomputed计算属性watc......