常见的hooks

1.useNamespace

javascript 复制代码
import { useNamespace } from '@element-plus/hooks'

useNamespace函数 是返回了符合BEM命名规则的方法。

BEM:

BEM是一种针对css的前端命名规范,是块(Block),元素(Element),修饰符(Modifier)的简写。

Block是模块,比如:article、dialog、sidebar、form、tab

Element为块里的元素,比如form里面的input、submit

modifier是对block或element的修饰,比如form--theme-dark

BEM的命名规范:

javascript 复制代码
.block { }
.block__element { }
.block--modifier { }
.block__element--modifier { } 

//使用__来连接block和element,使用--来连接block和modifier
javascript 复制代码
import { useNamespace } from './compo/useNamespace'
const bs = useNamespace('dialog')
ns.b() // el-dialog
ns.b('overlay') // el-dialog-overlay
ns.e('header') // el-dialog__header
ns.m('theme-dark') // el-dialog--theme-dark
ns.be('header','close') // el-dialog-header__close
ns.em('footer','small') // el-dialog__footer--small
ns.bm('footer','small') // el-dialog-footer--small
ns.bem('footer','btn','primary') // el-dialog-footer__btn--primary
ns.is('closeable') // is-closeable 



ns.b() 返回结果为 "el-dialog "
ms.b('overlay')
ns.e('header') 返回结果为 "el-dialog__header"
ns.m('theme-dark') 返回结果为 "el-dialog--theme-dark"
ns.be('header','close') 返回结果为 "el-dialog-header__close" 意思为返回一个block + element
ns.em('foter,'small') 返回结果为 "el-dialog__footer--small" 意思为返回一个element + modifier
ns.bm('footer','small') 返回结果为 "el-dialog-footer--small" 意思为返回一个block + modifier
ns.bem('footer','btn','primary') 返回结果为" el-dialog-footer__btn--primary" 意思为返回一个block+element+modifer
ns.is('closeable') 返回is-closeable 通常用来描述组件的状态,如is-closeable 表示:是否显示关闭

2. useElementBounding

提供了以下功能:

  • 边界信息获取,如果左边距left、宽度width等
  • 响应式更新,返回的边界信息是响应式的,目标元素的位置和尺寸变化时,会自动更新
  • 额为状态控制,还提供了一些额外的状态,例如目标元素是否可见,是否在屏幕内等

3.useWindowSize

可以获取窗口的宽度和高度,并且当窗口大小变化时自动更新

4.useEventListener

添加点击、键盘、滚动等监听事件

相关推荐
SchuylerEX5 分钟前
第六章 JavaScript 互操(2).NET调用JS
前端·c#·.net·blazor·ui框架
扛麻袋的少年43 分钟前
7.Kotlin的日期类
开发语言·微信·kotlin
东风西巷1 小时前
Rubick:基于Electron的开源桌面效率工具箱
前端·javascript·electron·软件需求
钢铁男儿1 小时前
Python 正则表达式实战:解析系统登录与进程信息
开发语言·python·正则表达式
探码科技1 小时前
AI知识管理软件推荐:九大解决方案与企业应用
前端·ruby
编程小黑马1 小时前
解决flutter 在控制器如controller 无法直接访问私有类方法的问题
前端
野生技术架构师2 小时前
2025年中高级后端开发Java岗八股文最新开源
java·开发语言
Miracle_G2 小时前
每日一个知识点:JavaScript 箭头函数与普通函数比较
javascript
unfetteredman2 小时前
Error: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32' not found
前端·javascript·vite
云存储小精灵2 小时前
Dify x 腾讯云 COS MCP:自然语言解锁智能数据处理,零代码构建 AI 新世界
前端·开源