当前位置: 首页 > article >正文

关于前端指令

在前端开发中,指令(Directives)通常指在框架中使用的一种特殊的语法或机制,用于扩展 HTML 的功能。常见的指令主要存在于前端框架中,如 Vue.js、Angular 等。下面我们将分别介绍 Vue.js 和 Angular 中的常用指令,并通过代码示例分析它们的作用。最后再讨论自定义指令的常见使用场景。


Vue.js 常用指令

Vue.js 提供了多种内置指令,用于与 DOM 元素交互。以下是常用指令及示例:

1. v-bind

用于动态绑定 HTML 元素的属性。

<img v-bind:src="imageUrl">

作用:将 imageUrl 数据绑定到 img 标签的 src 属性,当 imageUrl 变化时,src 会自动更新。

2. v-model

用于实现表单元素的双向数据绑定。

<input v-model="username">

作用:将 input 的值与 username 数据绑定,当用户输入时,username 会自动更新,反之亦然。

3. v-if / v-else / v-else-if

用于条件渲染。

<p v-if="score >= 90">优秀</p>
<p v-else-if="score >= 60">及格</p>
<p v-else>不及格</p>

作用:根据 score 的值动态渲染不同的内容。

4. v-for

用于列表渲染。

<ul><li v-for="item in items" :key="item.id">{{ item.name }}</li>
</ul>

作用:遍历 items 数组,渲染列表。

5. v-on

用于绑定事件监听器。

<button v-on:click="handleClick">点击我</button>

作用:为按钮绑定 click 事件,触发 handleClick 方法。

6. v-show

用于控制元素的显示/隐藏。

<div v-show="isVisible">显示内容</div>

作用:根据 isVisible 的值控制 div 的显示或隐藏(通过 display: none)。

Angular 常用指令

Angular 也提供了丰富的内置指令,以下是一些常见的:

1. *ngIf

用于条件渲染。

<p *ngIf="isLoggedIn">欢迎回来!</p>

作用:根据 isLoggedIn 的值决定是否渲染 p 元素。

2. *ngFor

用于列表渲染。

<ul><li *ngFor="let item of items">{{ item.name }}</li>
</ul>

作用:遍历 items 数组,渲染列表。

3. ngModel

用于双向数据绑定。

<input [(ngModel)]="username">

作用:将 input 的值与 username 双向绑定。

4. ngClass

用于动态添加 CSS 类。

<div [ngClass]="{'active': isActive, 'error': hasError}">内容</div>

作用:根据 isActivehasError 的值动态添加 activeerror 类。

5. ngStyle

用于动态添加样式。

<div [ngStyle]="{'color': textColor, 'font-size': fontSize}">内容</div>

作用:根据 textColorfontSize 的值动态设置样式。


常用自定义指令

在 Vue.js 和 Angular 中,可以创建自定义指令来扩展功能。

Vue.js 自定义指令
Vue.directive('focus', {inserted: function (el) {el.focus();}
});

使用:

<input v-focus>

作用:当页面加载时,自动聚焦到 input 元素。

Vue.js 提供了 Vue.directive 方法来创建自定义指令。以下是一个监听点击事件并执行自定义逻辑的示例

Vue.directive('custom-click', {bind(el, binding) {// 绑定点击事件el.addEventListener('click', () => {// 执行传入的回调函数if (typeof binding.value === 'function') {binding.value();}});},unbind(el) {// 解绑点击事件el.removeEventListener('click', () => {});}
});
使用示例
<div id="app"><button v-custom-click="handleClick">点击我</button>
</div><script>
new Vue({el: '#app',methods: {handleClick() {alert('按钮被点击了!');}}
});
</script>
解析
  1. bind:在指令绑定到元素时调用。这里我们监听了 click 事件。
  2. unbind:在指令解绑时调用。这里我们移除了 click 事件监听器。
  3. binding.value:获取指令绑定的值(即回调函数 handleClick)。
  4. 当按钮被点击时,会触发传入的回调函数 handleClick
Angular 自定义指令
@Directive({selector: '[appHighlight]'
})
export class HighlightDirective {constructor(private el: ElementRef) {}@HostListener('mouseenter') onMouseEnter() {this.el.nativeElement.style.backgroundColor = 'yellow';}@HostListener('mouseleave') onMouseLeave() {this.el.nativeElement.style.backgroundColor = '';}
}

使用:

<p appHighlight>鼠标悬停我</p>

作用:当鼠标悬停在 p 元素上时,背景色变为黄色。

自定义指令的常见应用

  1. DOM 操作

    • 场景:自动聚焦、滚动到某个元素、动态修改元素属性等。
    • 示例:v-focus 指令用于输入框自动聚焦。
  2. 事件处理

    • 场景:监听特定事件,执行自定义逻辑。             
    • 示例:appHighlight 指令用于鼠标悬停时动态改变背景色。
  3. 表单验证

    • 场景:自定义表单验证逻辑。
    • 示例:创建 v-validate 指令,实时验证输入内容是否符合规则。
  4. 第三方库集成

    • 场景:将第三方库(如 jQuery 插件)集成到框架中。
    • 示例:创建 v-datepicker 指令,将日期选择器插件与 Vue 或 Angular 集成。
  5. 性能优化

    • 场景:懒加载图片、组件或数据。
    • 示例:创建 v-lazy 指令,实现图片懒加载。

全局注册指令

全局注册的指令可以在应用的任何组件中使用。通常在 main.jsapp.js 中注册。

代码实现

import Vue from 'vue';// 定义自定义指令
Vue.directive('focus', {inserted(el) {el.focus();}
});// 或者使用简写形式
Vue.directive('focus', (el) => {el.focus();
});// 启动应用
new Vue({el: '#app'
});

使用示例

<input v-focus>

局部注册指令

局部注册的指令仅在特定组件中可用。

代码实现

export default {directives: {focus: {inserted(el) {el.focus();}}}
};

使用示例

<template><input v-focus>
</template><script>
export default {directives: {focus: {inserted(el) {el.focus();}}}
};
</script>

复杂指令的应用场景

1. DOM 操作和交互

场景:实现拖拽、缩放、滚动监听等复杂交互。

  • 示例
    • Vue.js 实现拖拽指令:
      • Vue.directive('drag', {bind(el) {let isDragging = false;el.addEventListener('mousedown', () => {isDragging = true;});document.addEventListener('mousemove', (e) => {if (isDragging) {el.style.left = `${e.clientX}px`;el.style.top = `${e.clientY}px`;}});document.addEventListener('mouseup', () => {isDragging = false;});}
        });
        
    • Angular 实现拖拽指令:​​​​​
      • @Directive({selector: '[appDrag]'
        })
        export class DragDirective {@HostListener('mousedown', ['$event']) onMouseDown(event: MouseEvent) {const element = this.el.nativeElement;const startX = event.clientX - element.offsetLeft;const startY = event.clientY - element.offsetTop;const onMouseMove = (e: MouseEvent) => {element.style.left = `${e.clientX - startX}px`;element.style.top = `${e.clientY - startY}px`;};const onMouseUp = () => {document.removeEventListener('mousemove', onMouseMove);document.removeEventListener('mouseup', onMouseUp);};document.addEventListener('mousemove', onMouseMove);document.addEventListener('mouseup', onMouseUp);}constructor(private el: ElementRef) {}
        }
        
2. 事件绑定和解绑

场景:监听复杂的用户交互事件(如长按、双击、滚动等)。

  • 示例
    • Vue.js 长按指令:
      • Vue.directive('longpress', {bind(el, binding) {let timeout;const handler = () => binding.value();el.addEventListener('mousedown', () => {timeout = setTimeout(handler, 1000);});el.addEventListener('mouseup', () => {clearTimeout(timeout);});}
        });
        
    • Angular 实现拖拽指令: 
      • @Directive({selector: '[appLongPress]'
        })
        export class LongPressDirective {@HostListener('mousedown') onMouseDown() {this.timeout = setTimeout(() => {this.callback();}, 1000);}@HostListener('mouseup') onMouseUp() {clearTimeout(this.timeout);}private timeout: any;@Input('appLongPress') callback: () => void;
        }
        

3. 动态样式和类名

场景:根据条件动态添加样式或类名。

  • 示例
Vue.directive('dynamic-class', {update(el, binding) {el.className = binding.value;}
});
4. 性能优化

场景:懒加载图片、虚拟滚动等。

  • 示例
    • Vue.js 图片懒加载指令:
      • Vue.directive('lazy', {inserted(el, binding) {const observer = new IntersectionObserver((entries) => {if (entries[0].isIntersecting) {el.src = binding.value;observer.unobserve(el);}});observer.observe(el);}
        });
        

 

设计复杂指令的注意事项

1. 指令的生命周期
  • Vue.js:需要了解 bindinsertedupdateunbind 等钩子函数。
  • Angular:需要了解 ngOnInitngAfterViewInitngOnDestroy 等生命周期钩子。
  • 注意:在指令解绑时(如 unbind 或 ngOnDestroy),一定要清除事件监听器、定时器或观察者,避免内存泄漏。
2. 指令的复用性
  • 设计指令时应尽量保持通用性,避免硬编码。
  • 通过参数化(如 binding.value 或 @Input)来实现灵活配置。
3. 性能优化
  • 避免在指令中进行频繁的 DOM 操作,减少重绘和回流。
  • 使用事件委托或防抖/节流技术优化高频事件(如滚动、拖拽)。
4. 指令的测试
  • 编写单元测试或端到端测试,确保指令在不同场景下的行为正确。
  • 使用工具(如 Jest、Karma)进行测试。
5. 指令的兼容性
  • 确保指令在不同浏览器和设备上的兼容性。
  • 对旧版浏览器使用 polyfill 或降级方案。

相关文章:

关于前端指令

在前端开发中&#xff0c;指令&#xff08;Directives&#xff09;通常指在框架中使用的一种特殊的语法或机制&#xff0c;用于扩展 HTML 的功能。常见的指令主要存在于前端框架中&#xff0c;如 Vue.js、Angular 等。下面我们将分别介绍 Vue.js 和 Angular 中的常用指令&#…...

ubuntu20.04系统没有WiFi图标解决方案_安装Intel网卡驱动

文章目录 1. wifi网卡配置1.1 安装intel官方网卡驱动backport1.1.1 第四步可能会出现问题 1.2 ubuntu官方的驱动1.3 重启 1. wifi网卡配置 我的电脑是华硕天选4&#xff08;i7&#xff0c;4060&#xff09;&#xff0c;网卡型号intel ax201 ax211 ax210通用。 参考文章&#…...

蓝桥杯day2:解码异或 后的数组

一、题意 未知 整数数组 arr 由 n 个非负整数组成。 经编码后变为长度为 n - 1 的另一个整数数组 encoded &#xff0c;其中 encoded[i] arr[i] XOR arr[i 1] 。例如&#xff0c;arr [1,0,2,1] 经编码后得到 encoded [1,2,3] 。 给你编码后的数组 encoded 和原数组 arr …...

Vite+微前端Qiankun-状态管理

一、前言 在微前端架构中&#xff0c;状态管理是一个重要的课题。由于子应用是独立的&#xff0c;它们之间可能需要共享状态或通信。以下是基于qiankun微前端架构的状态管理方案&#xff0c;结合Vue 3和Vite的实现。 二、状态管理方案 在微前端中&#xff0c;状态管理可以分为…...

【初学者】Python语言中有没有指针类型?

李升伟 整理 在Python语言中&#xff0c;没有像C或C那样的显式指针类型。Python的设计哲学强调简洁和易读&#xff0c;因此它隐藏了许多底层的细节&#xff0c;包括指针。 不过&#xff0c;Python中的变量可以被视为对对象的引用。当你创建一个对象并将其赋值给一个变量时&am…...

网络编程---多客户端服务器

写一个服务器和两个客户端 运行服务器和2个客户端&#xff0c;实现聊天功能 客户端1 和 客户端2 进行聊天 客户端1将聊天数据发送给服务器 服务器将聊天数据转发给客户端2 要求&#xff1a; 服务器使用 select 模型实现 客户端1使用 poll 模型实现 客户端2使用 多线程实现…...

SPACE_GAME

以下是一些關於星際遊戲的 GitHub 代碼範本&#xff0c;您可以根據需求進行修改或擴展。這裡提供一個簡單的 Python 代碼範例&#xff0c;展示如何創建一個簡單的星際遊戲框架。 專案結構 space_game/ ├── main.py ├── spaceship.py ├── enemy.py └── README.md1…...

Web Component 教程(五):从 Lit-html 到 LitElement,简化组件开发

前言 在现代前端开发中&#xff0c;Web 组件是一种非常流行的技术&#xff0c;它允许我们创建可重用的、自包含的 UI 元素。而 Lit-html 是一个简洁高效库&#xff0c;用于在 Web 组件中进行渲染。在这篇教程中&#xff0c;我们一步步学习如何 Lit-html 来创建 Web Component。…...

Vue3:构建高效用户界面的利器

一、Vue.js 简介​ Vue.js&#xff08;读音 /vjuː/, 类似于 view&#xff09;是一套构建用户界面的渐进式框架。它只关注视图层&#xff0c;采用自底向上增量开发的设计。Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件 &#xff0c;学习起来非常简单…...

LeetCode 2614.对角线上的质数:遍历(质数判断)

【LetMeFly】2614.对角线上的质数&#xff1a;遍历(质数判断) 力扣题目链接&#xff1a;https://leetcode.cn/problems/prime-in-diagonal/ 给你一个下标从 0 开始的二维整数数组 nums 。 返回位于 nums 至少一条 对角线 上的最大 质数 。如果任一对角线上均不存在质数&…...

红日靶场(二)——个人笔记

靶场搭建 新增VMnet2网卡 **web&#xff1a;**需要配置两张网卡&#xff0c;分别是外网出访NAT模式和内网域环境仅主机模式下的VMnet2网卡。 **PC&#xff1a;**跟web一样&#xff0c;也是需要配置两张网卡&#xff0c;分别是外网出访NAT模式和内网域环境仅主机模式下的VMn…...

实时视频分析的破局之道:蓝耘 MaaS 如何与海螺 AI 视频实现高效协同

一、蓝耘 MaaS 平台&#xff1a;AI 模型全生命周期管理的智能引擎 蓝耘 MaaS&#xff08;Model-as-a-Service&#xff09;平台是由蓝耘科技推出的 AI 模型全生命周期管理平台&#xff0c;专注于为企业和开发者提供从模型训练、推理到部署的一站式解决方案。依托云原生架构、高…...

清晰易懂的 Swift 安装与配置教程

初学者也能看懂的 Swift 安装与配置教程 本教程将手把手教你如何在 macOS 系统上安装 Swift&#xff0c;配置依赖包缓存位置&#xff0c;并指出新手容易踩坑的细节。即使你是零基础小白&#xff0c;也能快速上手&#xff01; 一、安装 Swift&#xff08;macOS 环境&#xff09…...

大数据 ETL 异常值缺失值处理完整方案

在大数据时代,数据已成为推动业务创新与决策优化的重要资产。然而,数据的海量、异构及实时性往往伴随着噪声、错误记录以及缺失现象,严重影响下游分析模型的准确性和可靠性。尤其在 ETL(抽取、转换、加载)环节中,如何在海量数据流中迅速甄别并处理异常数据,便成为决定整…...

macOS homebrew - 切换源

https://mirrors.tuna.tsinghua.edu.cn/help/homebrew/ 环境变量中 添加&#xff1a; export HOMEBREW_BREW_GIT_REMOTE"https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/brew.git" export HOMEBREW_CORE_GIT_REMOTE"https://mirrors.tuna.tsinghua.edu.cn…...

如何基于Gone编写一个Goner对接Apollo配置中心(下)—— 对组件进行单元测试

项目地址&#xff1a;https://github.com/gone-io/gone 原文地址&#xff1a;https://github.com/gone-io/goner/blob/main/docs/test_goner.md 本文介绍的例子&#xff0c;代码在&#xff1a;https://github.com/gone-io/goner/blob/main/apollo 文章目录 引言编写“可测试”的…...

走进Java:String字符串的基本使用

❀❀❀ 大佬求个关注吧~祝您开心每一天 ❀❀❀ 目录 一、什么是String 二、如何定义一个String 1. 用双引号定义 2. 通过构造函数定义 三、String中的一些常用方法 1 字符串比较 1.1 字符串使用 1.2 字符串使用equals() 1.3 使用 equalsIgnoreCase() 1.4 cpmpareTo…...

python系列之元组(Tuple)

不为失败找理由&#xff0c;只为成功找方法。所有的不甘&#xff0c;因为还心存梦想&#xff0c;所以在你放弃之前&#xff0c;好好拼一把&#xff0c;只怕心老&#xff0c;不怕路长。 python系列之元组&#xff08;Turple&#xff09; 一、元组是什么&#xff1f;——给新手的…...

破解验证码新利器:基于百度OCR与captcha-killer-modified插件的免费调用教程

破解验证码新利器&#xff1a;基于百度OCR与captcha-killer-modified插件的免费调用教程 引言 免责声明&#xff1a; 本文提供的信息仅供参考&#xff0c;不承担因操作产生的任何损失。读者需自行判断内容适用性&#xff0c;并遵守法律法规。作者不鼓励非法行为&#xff0c;保…...

批量删除 PPT 中的所有图片、某张指定图片或者所有二维码图片

PPT 文档中的图片如何删除呢&#xff1f;相信很多小伙伴或碰到类似的需求。比如我们需要删除 PPT 文档中的某一张图片或者某张二维码图片&#xff0c;如果每一页都有这张图片&#xff0c;或者有很多 ppt 都有同一张要删除的图片&#xff0c;我们应该怎么快速的完成删除呢&#…...

大模型开发(六):LoRA项目——新媒体评论智能分类与信息抽取系统

LoRA项目——新媒体评论智能分类与信息抽取系统 0 前言1 项目介绍1.1 项目功能1.2 技术原理1.3 软硬件环境1.4 项目结构 2 数据介绍与处理2.1 数据集介绍2.2 数据处理2.3 数据导入器 3 模型训练3.1 配置文件3.2 工具函数3.3 模型训练3.4 模型评估 4 模型推理 0 前言 微调里面&…...

mysql-innodb存储引擎主键索引叶子结点数据结构(非单纯的双向链表)

我们应该清楚行记录是放在页中的。 compact行记录格式&#xff1a; 主要介绍几个比较重要的参数 heap_no&#xff1a; 页号 record_type&#xff1a; 0 表示普通类型&#xff08;叶子结点&#xff09;&#xff0c;1表示B树的非叶子节点 &#xff0c;2 表示最小记录&#xff…...

MySQL 进阶学习文档

一、存储引擎 1.1 核心架构 四层架构&#xff1a;连接层 → 服务层 → 引擎层 → 存储层插件式存储引擎&#xff1a;不同引擎独立管理数据存储&#xff0c;可动态选择 1.2 主流引擎对比 特性InnoDB&#xff08;默认&#xff09;MyISAMMemory事务支持✅ 支持❌ 不支持❌ 不支…...

物联网为什么用MQTT不用 HTTP 或 UDP?

先来两个代码对比&#xff0c;上传温度数据给服务器。 MQTT代码示例 // MQTT 客户端连接到 MQTT 服务器 mqttClient.connect("mqtt://broker.server.com:8883", clientId) // 订阅特定主题 mqttClient.subscribe("sensor/data", qos1) // …...

Vmware中的centos7连接上网

有很多刚刚开始配置了centos7&#xff0c;然后发现不能上网现在来解决这个问题。 测试能不能上网 先还原这个设置&#xff0c;如果没有动过的话就不用&#xff0c;连接模式是NAT模式 然后进去设置网络环境&#xff0c;记得是用超级用户设置 vi /etc/sysconfig/network-script…...

【AI知识】常见的优化器及其原理:梯度下降、动量梯度下降、AdaGrad、RMSProp、Adam、AdamW

常见的优化器 梯度下降&#xff08;Gradient Descent, GD&#xff09;局部最小值、全局最小值和鞍点凸函数和非凸函数动量梯度下降&#xff08;Momentum&#xff09;自适应学习率优化器AdaGrad&#xff08;Adaptive Gradient Algorithm&#xff09;​RMSProp&#xff08;Root M…...

线性规划的标准形式

标准形式的定义 目标函数&#xff1a;最大化线性目标函数 其中&#xff0c;x 是决策变量向量&#xff0c;c 是目标系数向量。 约束条件&#xff1a;等式形式约束 A x b, 其中&#xff0c;A 是约束系数矩阵&#xff0c;b 是常数项向量。 变量非负约束&#xff1a; 。 因此…...

网络安全应急入门到实战

奇安信&#xff1a;95015网络安全应急响应分析报告&#xff08;2022-2024年&#xff09;官网可以下载 https://github.com/Bypass007/Emergency-Response-Notes 应急响应实战笔记 网络安全应急响应技术实战指南 .pdf 常见场景 第4章 勒索病毒网络安全应急响应 第5章 挖矿木…...

应用程序安全趋势:左移安全、人工智能和开源恶意软件

软件是大多数行业业务运营的核心&#xff0c;这意味着应用程序安全从未如此重要。 随着组织采用云原生架构、微服务和开源组件&#xff0c;攻击面不断扩大。结果是&#xff1a;攻击者渴望利用的易受攻击和恶意依赖项数量不断增加。 2025 年&#xff0c;安全团队将面临日益复杂…...

ospf动态路由

一、为什么使用动态路由 OSPF&#xff08;open shortest path first开放最短路径优先&#xff09;是内部网关协议(IGP)的一种&#xff0c;基于链路状态算法(LS)。 OSPF企业级路由协议(RFC2328 OSPFv2)&#xff0c;核心重点协议 OSPF共三个版本&#xff0c;OSPFV1主要是实验室…...