继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

【学习打卡】第 11 天 Vue3(3)

ICHAYA
关注TA
已关注
手记 40
粉丝 15
获赞 378

课程名称:前端框架及项目面试 聚焦 Vue3/React/Webpack
课程章节:第 6 章 Vue3 学习(新)
主讲老师:双越

课程内容:

今天学习的内容包括:
6-12 vue3 升级了哪些重要功能
6-13 Composition API 如何实现逻辑复用
6-14 Vue3 如何实现响应式
主要讲了 vue3 升级重点部分,举例获取鼠标坐标演示代码复用,回顾 vue2 响应式原理,和一点点 proxy

课程收获:

大概复述一下

vue3 升级部分

createApp 更新

const app = Vue.createApp({/*…*/})
app.use(/*…*/)

emit

export default {
  props: {
    msg: String,
  },
  // 需要声明
  emits: ["onSayHello"],
  // 传参
  setup(props, { emit }) {
    emit("onSayHello", "vue3");
  },
};

template 里可以是多个节点模板

异步组件

import { defineAsyncComponent } from "vue";
const AsyncComp = defineAsyncComponent(() =>
  import("./components/MyComponent.vue")
);

移除 filter,.sync

Teleport

被渲染在整个 Vue 应用外部的其他地方

<Teleport to="#modals">
  <div>A</div>
</Teleport>

等待异步组件 或者 async setup

<Suspense>
  <!-- 具有深层异步依赖的组件 -->
  <Dashboard />

  <!-- 在 #fallback 插槽中显示 “正在加载中” -->
  <template #fallback> Loading... </template>
</Suspense>

逻辑复用

定义方法 Fn 单独写在 js 里返回响应式的值

vue2 响应式原理回顾

Vue2 利用 Object.defineProperty(tar, key, {
get() {
//…
},
set() {
//…
}
})
对象深度监听需要一次性递归,无法监听新加删除属性,监听数组需要处理

proxy 基本使用

创建一个代理

const pd = new Proxy(data, {
  get(target, key, receiver) {
    return Reflect.get(target, key, receiver);
  },
  set(target, key, val, receiver) {
    return Reflect.set(target, key, val, receiver);
  },
  deleteProperty(target, key) {
    return Reflect.deleteProperty(target, key);
  },
});

图片描述图片描述

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP