前端又出最强 DX 新框架!这次是 Dlight.js!
liuian 2024-12-30 05:16 51 浏览
大家好,很高兴又见面了,我是"高级前端?进阶?",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 Dlight
DX-frist UI Rendering Library ResourcesDlight 是 DX-first 的 UI 渲染库。
具有以下核心特征:
- 开发简单:借助直观且用户友好的 API,无论开发者是构建简单的网站还是复杂的 Web 应用程序,使用 Dlight 进行 Web 开发都变得毫不费力。
- 高性能:DLight 的文件大小仅为 5KB,速度极快且超轻量,无需手动优化即可提供最佳性能。
- ? DX-first:DLight 使用函数调用和点符号的语法使开发更加容易,无需编写过时且难以阅读的 XML 代码。
- 直观简单:DLight 天生具有响应性,设计直观简单,具有极简的 API,无需记忆复杂的函数或库。
目前 Dlight 在 Github 通过 MIT 协议开源,短短几个月有超过 1k 的 star,是一个值得关注的前端开源项目。
如何使用 Dlight
响应性非常简单
Dlight 没有 ref()、 useState()、 createSignal()、$ 标记的计算状态、 memo()。如果想要状态、设置属性、计算属性可以设置另外一个属性,而且永远不会有冗余渲染。
@View
class MusicChooser {
@Prop musics
musicIdx = this.random()
music = this.musics[this.musicIdx]
random() {
return Math.floor(Math.random() * this.musics.length)
}
Body() {
PrettyBtn("Get a new song!")
.onClick(() => {
this.musicIdx = this.random()
})
MusicDisplay(music)
}
}无需三元运算符
DLight 采用 if 语句,开发者可以使用熟悉的条件语句(如 if-else、switch-case),就像编写普通 JavaScript 程序一样构建 UI。
@View
class MusicFavoriteItem {
@Prop musicItem
Body() {
MusicItem(this.musicItem)
div().onClick(this.musicItem.toggleFavorite); {
if (this.musicItem.favorite) {
FavoriteFilled()
} else {
FavoriteBorderOutlined()
.title("Like this song!")
}
}
}
}for 循环
在 DLight.js 中不会有任何新语法,如果要渲染数据数组只需使用 for 循环:
@View
class MusicList {
@Prop musicList
heading = `${this.musicList.length} ${
this.musicList.length > 1 ? "songs" : "song"
} by Lana Del Rey`
Body() {
section(); {
h1(this.heading)
for (const music of this.musicList) {
MusicItem(music)
}
}
}
}上下文的新范式
在所有框架中,没有一种解决方案可以让数据像传递 props 一样轻松地穿过不同的组件层。在 DLight.js 中,引入了一个名为 “Environment” 的概念,可以让开发者上下文数据传递比以往更加轻松。
@View
class Home {
@Env language
Body() {
h1(this.language === "zh" ? "音乐列表" : "Music List")
MusicList()
}
}
@View
class App {
language = "en"
Body() {
ChangeLanguageBtn()
.onClick(() => {
this.language = this.language === "en" ? "zh" : "en"
})
env().language(this.language); {
Home()
}
}
}更多关于 DLight.js 的用法和示例可以参考文末资料,本文不再过多展开。
参考资料
https://github.com/dlight-js/dlight
https://dlight.dev/
https://juejin.cn/post/7341593721100124200
相关推荐
- 笔记本不识别u盘怎么办(笔记本不识别优盘)
-
可能的原因是U盘没有正确连接到笔记本电脑上,或者U盘本身存在问题。以下是一些可能的解决方法:1.确保U盘正确连接:首先,检查U盘是否插入到笔记本电脑的USB接口中。如果已经插入,请尝试将U盘重新插拔...
- 电脑系统怎么修复(电脑系统怎么修复引导)
-
方法一:第一步:开机后长按【F8】按键直到【高级选项】出现即可。第二步:点击【最近的一次正确配置】并点击回车键修复。方法二:第一步:开机长按【F8】进入【安全模式】中去使用系统本身自带的系统还原。第二...
- 光猫wifi和路由器wifi冲突吗
-
光猫无线和路由无线可以同时使用,这两种无线路由器可以像路由器并联一样同时来使用光猫和无线路由一体机,是当今一种发展趋势,入户端可以先与光猫路由一体机连接,随后将路由器lan口和下一个无线路由的wan口...
- 笔记本价格走势网站(笔记本价格走势网站推荐)
-
1.打开慢慢买,搜索京东商品2.点击价格走势按钮即可
-
- 笔记本触摸板驱动是哪个(笔记本触摸板驱动是哪个软件)
-
1神舟笔记本的触摸板驱动为"ELANTECHTouchpadDriver"2这款驱动是针对神舟笔记本中所使用的触摸板硬件而设计的,可以提供更加稳定和流畅的触摸体验。3如果您需要下载或更新神舟笔记本的触摸板驱动,可以...
-
2025-12-13 05:05 liuian
- 苹果手机卡顿自动关机是什么原因
-
苹果卡关机可能是由于多种原因造成的,如系统崩溃、应用程序冲突、硬件故障等。如果你的苹果设备卡关机了,可以尝试按住电源键和Home键同时按下,重启设备。如果重启无效,可以尝试进入恢复模式或DFU模式进行...
- ps2020激活码序列号免费(ps2021激活账号和激活序列号免费)
-
ps2021和2020相比ps2021会好用一些。ps2021与ps2020版相比较新增了很多的功能,比如“NeuralGallery”滤镜,中文翻译为“神经画廊”,这个能够从ps2021的顶部菜单...
-
- 电脑屏幕亮度在哪里调(windows10怎么调亮度调节)
-
系统:win71打开电脑,单击鼠标右键,出现菜单后,点击个性化2进入个性化,点击左下角的显示图标3进去显示页面,点击左侧的调整亮度4在下方有一个亮度调节条,鼠标左键按住调节条上面的框,向左拖,屏幕就会调暗,向右拖,屏幕就会调亮了。首先看一下...
-
2025-12-13 03:05 liuian
- 电脑怎么恢复出厂设置方法(电脑这怎么恢复出厂设置)
-
电脑恢复出厂设置的步骤如下方法一:1、首先点击开始菜单图标,然后选择设置图标,接着在这里面选择更新和安全进入。2、在左侧栏目上找到恢复,然后选择重置此电脑下面的开始选项,就可以开始执行恢复系统的操作了...
- 快速清理电脑c盘(快速清理电脑c盘的软件)
-
方法一、简单直接粗暴的一键清理系统垃方法--bat来清理C盘空间垃圾 制作一键清理系统垃bat文件。在电脑桌面新建一个txt文本文档,将以下内容复制到txt文本文档里保存。方法二:借助360安全卫士...
- winpe使用教程(winpe winre)
-
大白菜PE是一款U盘装系统工具,可以帮助用户进行系统安装和维护。以下是大白菜PE的使用方法:下载大白菜PE:你可以在大白菜官网或其他网站上下载大白菜PE的安装文件。制作启动U盘:将一个空的U盘插入电脑...
- 电脑怎么看处理器配置(电脑如何查看处理器)
-
1,打开笔记本电脑,进入桌面直接打开“计算机”下面就有详细的计算机操作系统属性,和cpu、内存条基本信息。2,点击右侧栏目“设备管理器”就会弹出笔记本电脑所有的硬件配置信息。首要挑选重要的配置看,比如...
- 远程控制电脑软件哪个好用(远程控制电脑软件哪个好用点)
-
1.Teamviewer2.向日葵3.Windows自带的远程桌面。4.安企神软件推荐一款企业用的员工上网行为管理软件远程操纵也称远程控制,指管理人员在异地通过计算机网络异地拨号或双方都接入I...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
