首页 > 其他分享 >vue3新增特性合集

vue3新增特性合集

时间:2023-02-07 17:56:14浏览次数:64  
标签:Vue const hooks useMousePosition 特性 vue3 组件 import 合集

封装公共方法到原型上

再 vue2 中全局挂载方法使用的是 Vue.prototype.xxx 的形式来挂载的,但是在 vue3 中这个方法将不能使用,取而代之的是 app.config.globalProperties

任何全局的东西,应该谨慎使用。

  1. 挂载
    在 main.js 中进行挂载
import { createApp } from "vue";
import App from "./App";

const app = createApp(App);
app.config.globalProperties.$msg = "这是一个提示";
app.mount("#app");

2.使用

<script>
// 必须引入
import { getCurrentInstance } from "vue";
export default {
  setup() {
    const { proxy } = getCurrentInstance();
    console.log(proxy.$msg());
  },
};
</script>

Teleport——任意传送门

<Teleport> 是一个内置组件,这个组件的作用主要用来将模板内的 DOM 元素移动到其他位置。

  1. 场景
    像 modals,toast 等这样的元素,很多情况下,我们将它完全的和我们的 Vue 应用的 DOM 完全剥离,管理起来反而会方便容易很多

  2. 原因
    如果我们嵌套在 Vue 的某个组件内部,那么处理嵌套组件的定位、z-index 和样式就会变得很困难

另外,像 modals,toast 等这样的元素需要使用到 Vue 组件的状态(data 或者 props)的值
这就是 Teleport 派上用场的地方。我们可以在组件的逻辑位置写模板代码,这意味着我们可以使用组件的 data 或 props。然后在 Vue 应用的范围之外渲染它

  1. 使用
<Teleport to="body"> </Teleport>

<Teleport> 接收一个 to prop 来指定传送的目标。to 的值可以是一个 CSS 选择器字符串,也可以是一个 DOM 元素对象。这段代码的作用就是告诉 Vue“把以下模板片段传送到 body 标签下”。

hooks 函数

vue3 中的 hooks 就是函数的一种写法,就是将文件的一些单独功能的 js 代码进行抽离出来,放到单独的 js 文件中,或者说是一些可以复用的公共方法/功能。其实 hooks 和 vue2 中的 mixin 有点类似,但是相对 mixins 而言, hooks 更清楚复用功能代码的来源, 更清晰易懂。

:::tip
建议可以使用vueUse这个库,它为 Vue 开发人员提供了大量适用于 Vue 2 和 Vue 3 的基本 Composition API 实用程序函数。也就是一个 hooks 库
:::

  1. 在 src 中创建一个 hooks 文件夹,用来存放 hook 文件

  2. 老演员案例:封装一个获取页面坐标的方法(创建一个名叫useMousePosition.js的文件)

// src/hooks/useMousePosition.ts
import { ref, onMounted, onUnmounted, Ref } from "vue";

interface MousePosition {
  x: Ref<number>;
  y: Ref<number>;
}
function useMousePosition(): MousePosition {
  const x = ref(0);
  const y = ref(0);

  const updateMouse = (e: MouseEvent) => {
    x.value = e.pageX;
    y.value = e.pageY;
  };

// 创建点击事件
  onMounted(() => {
    document.addEventListener("click", updateMouse);
  });

// 销毁点击事件
  onUnmounted(() => {
    document.removeEventListener("click", updateMouse);
  });

  return { x, y };
}

export default useMousePosition;
  1. 使用 hooks 方法
<template>
  <div>
    <p>X: {{ x }}</p>
    <p>Y: {{ y }}</p>
  </div>
</template>

<script lang="ts">
import { defineComponent} from 'vue'
// 引入hooks
import useMousePosition from '../../hooks/useMousePosition'
export default defineComponent({
  setup () {
    // 使用hooks功能
    const { x, y } = useMousePosition()

    return {
      x,
      y
    }
  }
})
</script>

标签:Vue,const,hooks,useMousePosition,特性,vue3,组件,import,合集
From: https://www.cnblogs.com/icey-Tang/p/17099332.html

相关文章

  • PHP数组使用、特性、函数的总结
    包含其他数组的数组成为多维数组关联数组(即非数字索引数组)使用更有意义的数据作为数组的索引1、数组索引数组$products = array(‘a’, ‘b’, ‘c’);//就像一个......
  • vue3 中好用的插件
    1.Api自动导入unplugin-auto-import自动引入compositionapi,不需要再手动引入。(npm地址)下载npmi-Dunplugin-auto-import配置vite.config.tsimportAutoIm......
  • ObjectMapper 对象之间转换,针对两个对象属性名称不一样,这里用特性来关联
    ///<summary>///序列化+反射转换(针对两个对象属性名称不一样,这里用特性来关联)///</summary>///<typeparamname="TObject">目......
  • javaFX的几个新特性,让swing彻底过时
    首先声明,Java的GUI曾经是最弱的一环,毋庸置疑,而且历史上因为跟M$的斗争,导致Java失去了Desktop发展的最佳时间点,即便后来SUN&Oracle推出了JavaFX,Desktop......
  • vue3.0 同一项目中调用多个域名的请求
    1.简单粗暴形式:复制多个request.js文件,设置不同的baseUrl,根据需要引用不同的request.js文件。可以解决问题,但不推荐使用2.参数配置形式:利用参数配置,可灵活的调用多个不......
  • 抖音视频无水印下载器,抖音视频下载器,下载未开放下载权限的视频,支持批量下载,同一作者作
    抖音视频无水印下载,无下载权限的视频也能下,支持合集下载、批量下载!有些时候我们看到好看小姐姐的抖音作品,或者一些有价值的科普视频等,都希望将作品保存到本地,当一些作品的......
  • vue3 手写dropdown
    <template><divclass="drp_component":class="classname"><p@click="openDrp"class="ws-n"ref="drpDef"title=""><slot></slot></p></div......
  • 面试官:vue2和vue3的区别有哪些?
    一、Vue3与Vue2区别详述1.生命周期对于生命周期来说,整体上变化不大,只是大部分生命周期钩子名称上+“on”,功能上是类似的。不过有一点需要注意,Vue3在组合式API(Comp......
  • java8新特性之List处理
    1.集合中获取指定的一个属性值List<String>items=li.stream().map(ScdCostChargeItemEntity::getItem).collect(Collectors.toList()); 2.集合分组Map<String,......
  • JMM与线程三大特性
    并发与并行并发在早期单核CPU中,没办法同时运行多条指令,只能将多个应用程序分成不同的时间片,由于时间片切换的速度很快,所以看起来就像是多个应用程序同时运行。并发就是一......