Vue 3指令与事件处理


title: Vue 3指令与事件处理
date: 2024/5/25 18:53:37
updated: 2024/5/25 18:53:37
categories:

  • 前端开发

tags:

  • Vue3基础
  • 指令详解
  • 事件处理
  • 高级事件
  • 实战案例
  • 最佳实践
  • 性能优化

在这里插入图片描述

第1章 Vue 3基础

1.1 Vue 3简介

Vue 3 是一个由尤雨溪(尤大)领导的开源JavaScript框架,它专注于构建用户界面。相较于Vue 2,Vue 3在核心理念上保持一致,但对一些底层实现进行了重大优化,包括:

  • SFC(Single File Component) : Vue 3继续支持SFC模式,将组件的模板、样式和逻辑集成在一个文件中。
  • Composition API: 引入新的编程模型,强调组件内部状态的可组合性,而非依赖于props和data。
  • TypeScript支持: 提供了更好的类型系统,方便开发者编写类型安全的代码。
  • Performance: 通过移除一些不必要的依赖,提高了性能,特别是对于大型应用。

1.2 安装与配置

1.2.1 环境准备

  • Node.js: Vue 3需要Node.js环境,建议使用最新版本。
  • 使用npm或yarn: 作为包管理器,安装Vue CLI(命令行工具)。

1.2.2 Vue CLI安装

  • 打开终端(或命令提示符):
npm install -g @vue/cli

  • 或者使用yarn:
yarn global add @vue/cli

1.2.3 创建项目

  • 创建一个新的Vue 3项目:
vue create my-project

  • 进入项目目录:
cd my-project

1.2.4 配置基本文件

  • 修改src/main.js,引入Vue实例并启动应用:
import { createApp } from 'vue';
import App from './App.vue';

const app = createApp(App);
app.mount('#app');

1.3 模板语法

1.3.1 JSX-like模板 Vue 3的模板语法采用类似React的JSX语法,但更简洁。如创建一个Hello World组件:

<template>
  <div>Hello, {{ name }}!</div>
</template>

<script>
export default {
  data() {
    return {
      name: 'World',
    };
  },
};
</script>

  • {{ }}用于插值表达式,{{{ }}}用于文本插值。
  • <div>是标签,<template>用于包裹组件内容。

1.3.2 简化模板 Vue 3还支持更简洁的模板语法,如:

<template>
  <div>Hello, {{ name }}!</div>
</template>
<script>
export default {
  data() {
    return { name: 'World' };
  },
};
</script>

  • 省略了<script>标签内的export defaultdata

第2章 Vue 3指令

2.1 内置指令

Vue 3提供了多种内置指令,用于控制DOM的行为和渲染。以下是一些常用的内置指令:
AD:漫画首页

2.1.1 v-bind

v-bind 指令用于动态地绑定一个或多个属性,或者一个组件 prop 到表达式。在Vue 3中,v-bind 可以简写为 :

示例:

<template>
  <img :src="imageSrc" alt="Image">
</template>
<script>
export default {
  data() {
    return {
      imageSrc: 'https://example.com/image.jpg',
    };
  },
};
</script>

2.1.2 v-model

v-model 指令用于在表单控件或者组件上创建双向数据绑定。

示例:

<template>
  <input v-model="message" placeholder="edit me">
  <p>Message is: {{ message }}</p>
</template>
<script>
export default {
  data() {
    return {
      message: '',
    };
  },
};
</script>

2.1.3 v-on

v-on 指令用于监听DOM事件,并在触发时执行一些JavaScript代码。v-on 可以简写为 @

示例:

<template>
  <button @click="incrementCounter">Click me</button>
</template>
<script>
export default {
  data() {
    return {
      counter: 0,
    };
  },
  methods: {
    incrementCounter() {
      this.counter++;
    },
  },
};
</script>

2.1.4 v-show与v-if

v-showv-if 指令用于条件性地渲染一块内容。v-show 是通过CSS控制元素的显示与隐藏,而 v-if 则是通过创建或销毁DOM元素来控制。

示例:

<template>
  <p v-show="isVisible">This is shown by v-show</p>
  <p v-if="isVisible">This is shown by v-if</p>
</template>
<script>
export default {
  data() {
    return {
      isVisible: true,
    };
  },
};
</script>

2.1.5 v-for

v-for 指令用于基于源数据多次渲染元素或模板块。

示例:

<template>
  <ul>
    <li v-for="item in items" :key="item.id">
      {{ item.text }}
    </li>
  </ul>
</template>
<script>
export default {
  data() {
    return {
      items: [
        { id: 1, text: 'Item 1' },
        { id: 2, text: 'Item 2' },
        { id: 3, text: 'Item 3' },
      ],
    };
  },
};
</script>

2.1.6 v-text与v-html

v-text 指令用于更新元素的 textContent。v-html 指令用于更新元素的 innerHTML。

示例:

<template>
  <p v-text="textContent"></p>
  <p v-html="htmlContent"></p>
</template>
<script>
export default {
  data() {
    return {
      textContent: 'This is text content',
      htmlContent: '<span>This is HTML content</span>',
    };
  },
};
</script>

通过这些内置指令,Vue 3允许开发者以声明式的方式控制DOM,使得代码更加简洁和易于维护。

2.2 自定义指令

除了内置指令,Vue 3还允许开发者创建自定义指令。自定义指令可以用于执行更多复杂的DOM操作。

2.2.1 创建自定义指令

可以使用 directives 选项在组件中注册自定义指令。

示例:

export default {
  directives: {
    focus: {
      // 指令的定义
      mounted(el) {
        el.focus();
      },
    },
  },
};

2.2.2 钩子函数

自定义指令可以包含以下几个钩子函数:

  • bind:只调用一次,指令第一次绑定到元素时调用。
  • inserted:被绑定元素插入到父节点时调用(仅保证父节点存在,但不一定已被插入到文档中)。
  • updated:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新。
  • componentUpdated:所在组件的 VNode 及其子 VNode 全部更新后调用。
  • unbind:只调用一次,指令与元素解绑时调用。

示例:

export default {
  directives: {
    focus: {
      bind(el) {
        console.log('focus bind');
      },
      inserted(el) {
        console.log('focus inserted');
      },
      updated(el) {
        console.log('focus updated');
      },
      componentUpdated(el) {
        console.log('focus componentUpdated');
      },
      unbind(el) {
        console.log('focus unbind');
      },
    },
  },
};

2.2.3 指令参数与修饰符

自定义指令可以接受一个参数,该参数是一个字符串,表示指令的修饰符。修饰符是一个 prefiex,以 . 开头,用于指明指令应该以特殊方式绑定。

示例:

export default {
  directives: {
    focus: {
      bind(el, binding) {
        if (binding.arg === 'input') {
          el.focus();
        }
      },
    },
  },
};

可以在使用自定义指令时,使用 v-bind 传递参数。

示例:

<template>
  <input v-focus.input="">
</template>

通过自定义指令,开发者可以扩展 Vue 的功能,并在组件中实现更多复杂的DOM操作。

第3章 Vue 3事件处理

3.1 Vue 3事件处理

Vue 3的事件处理机制与Vue 2类似,但使用了更简洁的语法。Vue 3中不再直接支持v-on,而是使用@符号来绑定事件。

3.1.1 基本事件绑定

基础的事件绑定使用 @ 符号,后跟事件名称,再加事件处理函数。例如:

<button @click="handleClick">点击我</button>

对应的JavaScript部分:

export default {
  methods: {
    handleClick() {
      console.log('Button clicked');
    },
  },
};

3.1.2 事件修饰符

Vue 3的事件修饰符与Vue 2兼容,包括:

  • .prevent:阻止事件的默认行为(如阻止表单的默认提交)
  • .stop:阻止事件的进一步传播(默认行为不会被阻止)
  • .capture:在捕获阶段触发,从根元素开始向上
  • .self:仅在事件源和触发元素相同时触发
  • .passive:在触摸移动事件中,用于处理滚动,使事件在默认行为执行前触发,常用于阻止滚动

例如:

<button @click.prevent="handleClick">阻止默认</button>

3.1.3 按键修饰符

  • .once:只触发一次,然后移除事件监听
  • .key:用于键盘事件,指定一个键值(如 EnterEsc)来监听

例如:

<input @keyup.enter="handleEnter" />

在这个例子中,当用户按下回车键时,handleEnter 方法会被调用。

3.2 事件处理函数

在Vue 3中,事件处理函数是响应用户交互的关键部分,它们可以以不同的形式存在,包括内联事件处理器、方法事件处理器以及结合计算属性和侦听器。

3.2.1 内联事件处理器

内联事件处理器是指直接在模板中定义的JavaScript表达式,它们通常用于简单的逻辑。例如:

<button @click="count++">增加计数</button>

在这个例子中,点击按钮会直接增加count的值。

3.2.2 方法事件处理器

方法事件处理器是指在Vue组件的methods选项中定义的函数,这些函数可以处理更复杂的逻辑。例如:

export default {
  data() {
    return {
      count: 0,
    };
  },
  methods: {
    incrementCount() {
      this.count++;
    },
  },
};

在模板中使用:

<button @click="incrementCount">增加计数</button>

3.2.3 计算属性与侦听器

计算属性和侦听器也可以用于事件处理,尤其是在需要根据数据变化来更新视图或执行某些操作时。

  • 计算属性:计算属性是基于它们的依赖进行缓存的,只有当依赖变化时才会重新计算。例如:
export default {
  data() {
    return {
      firstName: 'John',
      lastName: 'Doe',
    };
  },
  computed: {
    fullName() {
      return `${this.firstName} ${this.lastName}`;
    },
  },
};

在模板中使用计算属性:

<button @click="fullName = 'Jane Smith'">更改全名</button>

  • 侦听器:侦听器用于观察和响应Vue实例上的数据变动。例如:
export default {
  data() {
    return {
      message: 'Hello',
    };
  },
  watch: {
    message(newVal, oldVal) {
      console.log(`Message changed from ${oldVal} to ${newVal}`);
    },
  },
};

在模板中触发侦听器:

<button @click="message = 'Hello, Vue 3'">更改消息</button>

通过这些不同类型的事件处理函数,Vue 3提供了灵活且强大的工具来处理用户交互和数据变化。

第4章 高级事件处理

在Vue中,高级事件处理技术包括使用事件总线、自定义事件和事件委托,这些技术可以帮助开发者更有效地管理组件间的通信和事件处理。

4.1 事件总线

事件总线是一个中央集线器,用于在非父子关系的组件之间传递事件。在Vue 2中,通常使用一个空的Vue实例作为事件总线。但在Vue 3中,推荐使用mitttiny-emitter等第三方库,因为Vue 3移除了$on$off$once等实例方法。

使用事件总线的基本步骤如下:

  1. 创建事件总线:
import mitt from 'mitt';
export const emitter = mitt();

  1. 在发送组件中触发事件:
this.emitter.emit('eventName', data);

  1. 在接收组件中监听事件:
this.emitter.on('eventName', this.handleEvent);

4.2 自定义事件

自定义事件是Vue中组件间通信的另一种方式,特别是在父子组件之间。子组件可以使用$emit方法触发一个自定义事件,父组件则通过在子组件标签上使用v-on@来监听这个事件。

示例:

子组件:

methods: {
  handleClick() {
    this.$emit('custom-event', '传递的数据');
  }
}

父组件:

<child-component @custom-event="handleCustomEvent"></child-component>

4.3 事件委托

事件委托是一种优化事件处理的技术,它利用事件冒泡机制,将事件处理器添加到父元素上,而不是每个子元素上。这样可以减少内存消耗和提高性能,尤其是在有很多子元素需要监听相同事件的情况下。
AD:专业搜索引擎

在Vue中实现事件委托的示例:

<ul @click="handleClick">
  <li v-for="item in items" :key="item.id">{{ item.text }}</li>
</ul>

methods: {
  handleClick(event) {
    const target = event.target;
    if (target.tagName === 'LI') {
      // 处理点击事件
    }
  }
}

在这个例子中,handleClick方法会监听<ul>元素上的点击事件,并通过检查事件目标来确定是否是<li>元素被点击。这样,无论有多少个<li>元素,都只需要一个事件处理器。

第5章 实战案例

以下是一些Vue.js简单实战案例,涵盖了表单处理、列表渲染与过滤、动态组件与异步组件的应用。

5.1 表单处理

表单处理是前端应用中常见的需求,Vue提供了简洁的方法来处理表单输入。

<template>
  <div>
    <form @submit.prevent="submitForm">
      <input v-model="form.name" placeholder="Name">
      <input v-model="form.email" type="email" placeholder="Email">
      <button type="submit">Submit</button>
    </form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      form: {
        name: '',
        email: ''
      }
    };
  },
  methods: {
    submitForm() {
      // 处理表单提交逻辑
      console.log('Name:', this.form.name);
      console.log('Email:', this.form.email);
    }
  }
};
</script>

5.2 列表渲染与过滤

列表渲染是Vue中的基础功能,结合过滤器可以实现复杂的数据展示。

<template>
  <div>
    <input v-model="search" placeholder="Search">
    <ul>
      <li v-for="item in filteredList" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      search: '',
      items: [
        { id: 1, name: 'Apple' },
        { id: 2, name: 'Banana' },
        { id: 3, name: 'Cherry' },
        // 更多数据...
      ]
    };
  },
  computed: {
    filteredList() {
      return this.items.filter(item => item.name.includes(this.search));
    }
  }
};
</script>

5.3 动态组件与异步组件

动态组件和异步组件可以提高应用的灵活性和性能。

<template>
  <div>
    <button @click="component = 'ChildA'">切换到ChildA</button>
    <button @click="component = 'ChildB'">切换到ChildB</button>
    <component :is="component"></component>
  </div>
</template>

<script>
export default {
  data() {
    return {
      component: 'ChildA'
    };
  },
  components: {
    ChildA: { template: '<div>This is ChildA</div>' },
    ChildB: { template: '<div>This is ChildB</div>' }
  }
};
</script>

异步组件的实现通常涉及到动态导入:

components: {
  ChildA: () => import('./ChildA.vue'),
  ChildB: () => import('./ChildB.vue')
}

这样,ChildA和ChildB组件会按需加载,从而提高应用的性能。

第6章 最佳实践

在Vue.js开发中,遵循一些最佳实践可以提高应用的性能、代码的可维护性和可测试性。以下是关于性能优化、代码组织与重用、测试与调试的最佳实践。AD:首页 | 一个覆盖广泛主题工具的高效在线平台

6.1 性能优化

  1. 使用v-if替代v-show:在需要频繁切换显示状态时,使用v-ifv-show更高效。
  2. 合理使用计算属性:对于复杂的数据处理,使用计算属性可以减少重复计算,提高性能。
  3. 避免不必要的组件渲染:使用v-once指令可以渲染一次后不再更新,适用于静态内容。
  4. 异步组件和代码分割:使用异步组件和Webpack的代码分割功能,可以按需加载组件,减少初始加载时间。
  5. 使用keep-alive缓存组件:对于需要频繁切换但数据不变的组件,使用<keep-alive>可以避免重复渲染。

6.2 代码组织与重用

  1. 组件化开发:将UI拆分为可重用的组件,每个组件负责特定的功能。
  2. 遵循单一职责原则:每个组件或模块应只负责一个功能,提高代码的可维护性和可测试性。
  3. 使用Mixins或Composition API:对于组件间的共享逻辑,可以使用Mixins或Vue 3的Composition API。
  4. 模块化管理状态:使用Vuex或其他状态管理工具来管理应用的状态,确保状态的可预测性和可维护性。
  5. 代码风格一致:遵循统一的代码风格和命名规范,提高代码的可读性。

6.3 测试与调试

  1. 单元测试:为组件和关键逻辑编写单元测试,确保代码的正确性。可以使用Jest或Vue Test Utils等工具。
  2. 端到端测试:使用Cypress或Puppeteer等工具进行端到端测试,确保应用在真实环境中的表现符合预期。
  3. 使用Vue Devtools:利用Vue Devtools进行调试,可以直观地查看组件树、状态和事件。
  4. 日志和错误处理:在关键点添加日志输出,便于追踪问题。使用try-catch处理可能的错误,提高应用的健壮性。
  5. 持续集成:将测试集成到持续集成流程中,确保每次代码提交都经过自动化测试。

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

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

相关文章

5.22-wjn

使用select实现的TCP并发服务器端 #define SER_PORT 8888 #define SER_IP "192.168.125.158" int main(int argc, const char *argv[]) {//1、为通信创建一个端点int sfd socket(AF_INET, SOCK_STREAM, 0);//参数1&#xff1a;说明使用的是ipv4通信域//参数2&#…

SpringBoot Bean

配置优先级 Bean的管理 从IOC容器中获取Bean对象&#xff1a;注入IOC容器对象 bean的作用域 Bean对象默认在容器启动时实例化 Lazy在第一次使用时初始化 Bean的管理&#xff1a;第三方Bean 引入依赖&#xff0c;每次解析创建新对象&#xff0c;浪费资源 将第三方对象交给…

vr商品全景展示场景编辑软件的优点

3D模型展示网站搭建编辑器以强大的3D编辑引擎和逼真的渲染效果&#xff0c;让您轻松实现模型展示的优化。让用户通过简单的操作&#xff0c;就能满足个人/设计师/商户多样化展示的需求&#xff0c;让您的模型成为独一无二的杰作。 3D模型展示网站搭建编辑器采用国内领先的实时互…

软件设计师中级

计算机系统 运算器和控制器 算术逻辑单元 累加寄存器器 状态寄存器 数据缓冲寄存器 指令寄存器 程序计数器 地址寄存器 指令译码器 内存按字节编址 内存存储单元16位 1 浮点数 浮点数范围&#xff1a;-2的(2的阶码次)-1到-2的(2的阶码次)-1 乘 1-2负尾数次 海明码 海明码&…

力扣HOT100 - 136. 只出现一次的数字

解题思路&#xff1a; class Solution {public int singleNumber(int[] nums) {int single 0;for (int num : nums) {single ^ num;}return single;} }

Java基础的语法---StringBuilder

StringBuilder 构造方法 StringBuilder()&#xff1a;创建一个空的StringBuilder实例。 StringBuilder(String str)&#xff1a;创建一个StringBuilder实例&#xff0c;并将其初始化为指定的字符串内容。 StringBuilder(int a): 创建一个StringBuilder实例…

AWTK实现汽车仪表Cluster/DashBoard嵌入式GUI开发(七):快启

前言: 汽车仪表是人们了解汽车状况的窗口,而仪表中的大部分信息都是以指示灯形式显示给驾驶者。仪表指示灯图案都较为抽象,对驾驶不熟悉的人在理解仪表指示灯含义方面存在不同程度的困难,尤其对于驾驶新手,如果对指示灯的含义不求甚解,有可能影响驾驶的安全性。即使是对…

Leetcode刷题笔记3:链表基础1

导语 leetcode刷题笔记记录&#xff0c;本篇博客记录链表基础1部分的题目&#xff0c;主要题目包括&#xff1a; 203.移除链表元素707.设计链表206.反转链表 知识点 链表 链表是一种通过指针串联在一起的线性结构&#xff0c;每一个节点由两部分组成&#xff0c;一个是数据…

企业如何防止数据泄密?大型企业必备的文件加密软件

随着信息化建设的大步推进&#xff0c;越来越多的企业资料以电子文件的形式保存&#xff0c;企业内部和企业之间的信息交流也主要依靠电子文件。近年来的泄密事件层出不穷&#xff0c;比如东软泄密案、HTC窃密案、力拓案等&#xff0c;给企业带来灾难性的经济损失及信誉重创。如…

CentOS7安装内网穿透实现远程推送镜像到本地Docker Registry

文章目录 前言1. 部署Docker Registry2. 本地测试推送镜像3. Linux 安装cpolar4. 配置Docker Registry公网访问地址5. 公网远程推送Docker Registry6. 固定Docker Registry公网地址 前言 本文主要介绍如何部署Docker Registry 本地镜像仓库,简单几步结合cpolar内网穿透工具实现…

使用控制台方式部署sentinel

1.下载控制台jar包 2.运行jar包 java -jar sentinel-dashboard-1.8.0.jar 也可以通过编写批处理文件指定端口、用户名、密码&#xff1a; 客户端添加依赖&#xff08;后续整合springcloudalibaba时不需要此依赖&#xff09; 如修改了sentinel端口&#xff0c;需要添加客户端运…

ubuntu下载离线软件包及依赖

目录 一、前言 二、正文 1.准备环境 2.开始下载 3.后续工作 三、总结 一、前言 由于给客户提供的设备机不允许上网&#xff0c;那么所有待安装的软件包及依赖库都需要提前下载好&#xff0c;然后通过局域网传过去再安装。 另外&#xff0c;软件包可能还依赖其他的库&…

【Pytorch】【MacOS】14.m1芯片使用mps进行深度模型训练

读者要先自行安装python以及anaconda&#xff0c;并且配置pytorch环境 第一步 测试环境 import torch # 判断macOS的版本是否支持 print(torch.backends.mps.is_available()) # 判断mps是否可用 print(torch.backends.mps.is_built())如果第一个语句为False&#xff0c;说明当前…

自定义一个SpringBoot场景启动器

前言 一个刚刚看完SpringBoot自动装配原理的萌新依据自己的理解写下的文章&#xff0c;如有大神发现错误&#xff0c;敬请斧正&#xff0c;不胜感激。 分析SpringBoot自动配置原理 SpringBoot的启动从被SpringBootApplication修饰的启动类开始,SpringBootApplicaiotn注解中最…

浅谈后端boot框架整合第三方技术JUnit MyBatis Druid整体思想

整合第三方技术 不要单单学习指定技术与springboot整合的方式 学习目标的是整合整体的技术的思路 拿到任何一个第三方技术后我们在springboot中如何操作 这是真正我们应该学习的东西 以后能整合任意技术 整合JUnit JUnit 是一个流行的开源测试框架&#xff0c;用于 Java …

Redis优化笔记

Redis优化 一&#xff1a;Key&#xff1a; 1.1.Key的规范&#xff1a; 测试如下&#xff1a; 1.2.拒绝BigKey&#xff1a; 我们可以用&#xff1a; MEMORY USAGE name命令来看它的大小。 注意&#xff0c;这里的第二种之所以不使用Keys *&#xff0c;因为在实际生产时&#…

NDIS小端口驱动开发(一)

在四种NDIS相关的驱动中&#xff0c;微型端口驱动(也经常翻译为为小端口驱动)位于驱动栈的底部&#xff0c;一般将它理解为NIC设备的驱动程序&#xff1a; 有几种类型的微型端口驱动程序类型&#xff1a; 无连接微型端口驱动程序用于控制无连接网络媒体 &#xff0c;如以太网的…

SpringBoot接入Knife4j接口文档

0.介绍 1&#xff09; Knife4j是什么 Knife4j是Java MVC框架集成Swagger生成Api文档的增强解决方案&#xff0c;前身是swagger-bootstrap-ui&#xff0c;有着比Swagger更为美观的UI以及功能。 例如以下效果图&#xff1a; 2&#xff09; 官方链接 官网&#xff1a;Knife4j …

FastSAM 部署 rknn

基于yolov8(ultralytics)工程导出的FastSAM的onnx模型&#xff0c;后处理和yolov8seg是一样的。      模型和完整测试代码。 1 FastSAM 导出 onnx 导出onnx的方式有两种&#xff0c;一种使用FastSAM工程&#xff0c;一种是使用yolov8(ultralytics)工程。本篇博客使用yolov…

2024年【N1叉车司机】免费试题及N1叉车司机模拟试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 N1叉车司机免费试题考前必练&#xff01;安全生产模拟考试一点通每个月更新N1叉车司机模拟试题题目及答案&#xff01;多做几遍&#xff0c;其实通过N1叉车司机模拟考试题库很简单。 1、【多选题】《中华人民共和国特…