网站首页 > 技术文章 正文
大家好,很高兴又见面了,我是"高级前端?进阶?",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 Dlight
DX-frist UI Rendering Library Resources
Dlight 是 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
猜你喜欢
- 2025-06-18 腾讯开源 Kuikly 框架,跨端开发新突破
- 2025-06-18 腾讯即将开源Kuikly:基于Kotlin的纯原生跨端解决方案
- 2024-10-04 基于 Ant Design Vue 的中后台管理系统框架
- 2024-10-04 InfoWorld 权威盘点:2023 年最值得关注的五个前端开源库
- 2024-10-04 今日推荐:Cognita】一款开源框架 tcc开源框架
- 2024-10-04 为何前端 4 大主流框架都选择拥抱 happy-dom?
- 2024-10-04 推荐一个超漂亮开源的简单易用的中后台模版
- 2024-10-04 4大顶级零JavaScript Go框架大火,前端凉凉?
- 2024-10-04 TDesign:腾讯的开源企业级前端框架,能和ant-design一战吗?
- 2024-10-04 开源前端框架——“锋利的jQuery”发布4.0首个Beta版本
你 发表评论:
欢迎- 532℃Oracle分析函数之Lag和Lead()使用
- 531℃几个Oracle空值处理函数 oracle处理null值的函数
- 529℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 519℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 514℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 505℃【数据统计分析】详解Oracle分组函数之CUBE
- 484℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 483℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)