仲灏小栈 仲灏小栈
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

仲灏

诚意, 正心, 格物, 致知
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 《前端项目基础建设》
  • HTML&CSS

  • JavaScript&TypeScript

  • Node

  • 构建

  • Vue

    • 持久化存储实时读取
    • vue自适应布局
    • Vue 中后台表格的增删改查统一解决方案(mixin版)
    • Vue 中后台表格的增删改查同一解决方案(组件封装版)
    • Vue Render自定义table单元格内容
    • 项目初始化编码规范(eslint,prettier等)
    • vue element-ui 换肤功能开发
    • vue element 定义多种主题实现换肤
    • 大屏自适应容器
    • el-upload 自定义上传进度
    • vue3初学注意点
      • 生命周期
      • watch
      • defineComponent
        • suspens
    • vue3 hooks 自适应可视化大屏
    • vue3 element-plus ant- design 自定义主题
    • 博客开发
    • vue2中使用jsx
    • Vue 放弃繁琐的render函数,拥抱JSX
    • 组件设计步骤
    • 倒计时验证
    • Vue中computed和watch的区别
    • vue3面试聚焦
    • Vue3 原理 Proxy实现响应式
  • React

  • 小程序

  • 跨端

  • Electron

  • WebGL&GIS

  • 浏览器

  • 面经

  • 其他

  • 大前端
  • Vue
仲灏
2022-01-07
目录

vue3初学注意点

  • 解构会失去响应式功能, 如
const foo = {
  x: 0,
  y: 0
}
const { x } = foo
console.log(x) // 0

foo.x = 1
console.log(x) // 0

console.log(foo.x) // 1
1
2
3
4
5
6
7
8
9
10
11

image-20220107222750735

当然你后面对数据重新解构是能获取最新的值的

import { toRefs, reactive } from vue
...
setup() {
  const data = reactive({
    count: 0
  })
	const refData = toRefs(data)
  return {
		...refData
	}
}
1
2
3
4
5
6
7
8
9
10
11

# 生命周期

// vue2  to vue3

beforeCreate	->	use setup()

created	->	use setup()

beforeMount	->	onBeforeMount

mounted	->	onMounted

beforeUpdate	->	onBeforeUpdate

updated			->		onUpdated

destroyed		->		onUnmounted

activated		->		onActivated

deactivated	->		onDeactivated

errorCaptured	->	onErrorCaptured



// new

onRenderTracked

onRenderTriggerd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29

# watch

  • setup 是和beforeCreate 和 created 一起运行的,而且只执行一次,在后续操作中不会再触发。如果需要出发多次需要引入watch 等函数

  • 如果watch中对单独某个响应式对象中的某个属性进行监听,就需要使用方法返回这个对象的属性,否则你直接写某个属性那么也会失去响应式属性

  • import { watch, reactive } from vue
    ...
    setup() {
      const data = reactive({
        count: 0
      })
      watch([data.count], (newVal, oldVal) => { // 回报如下错误
        ...
      }) 
    }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
  • image-20220107225456709

  // 更正后
	watch([() => data.count], (newVal, oldVal) => { 
    ...
  }) 

1
2
3
4
5

# defineComponent

defineComponent 这个并没有实现任何逻辑 完全是服务typescript 存在的

# 新功能

# suspens

上次更新: 2022/06/05, 20:31:36
el-upload 自定义上传进度
vue3 hooks 自适应可视化大屏

← el-upload 自定义上传进度 vue3 hooks 自适应可视化大屏→

最近更新
01
vim日常使用记录
04-02
02
滑动窗口最大值
04-02
03
有效的字母异位词
04-02
更多文章>
Theme by Vdoing | Copyright © 2021-2025 izhaong | github | 蜀ICP备2021031194号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式