widgets/index.js

56 lines
2.8 KiB
JavaScript
Raw Normal View History

2024-09-06 01:08:14 +08:00
import { div, span, pre, h1, h2, p, ul, li, button, createElement } from './main.js'
2024-09-05 10:26:23 +08:00
import { Dialog } from './widgets/dialog.js'
2024-01-12 04:38:20 +08:00
2024-09-06 01:08:14 +08:00
document.body.style.fontFamily = 'Arial, sans-serif'
document.body.style.fontSize = '14px'
2024-09-05 22:30:01 +08:00
document.body.appendChild(div.absolute.t_2.r_2.bg_red_500.childs([
div.text('会话/账户')
2024-08-26 01:00:32 +08:00
]))
2024-09-05 21:59:31 +08:00
document.body.appendChild(div.cursor_pointer.bg_red_500.overflow_clip.w_1000.childs([
h1.m_2rem.pt_2rem.text('Widgets!'),
2024-09-06 01:08:14 +08:00
p.m('1rem').p({ top: '1rem' }).text('是什么, 为什么, 怎么做?'),
ul.m('1rem').p({ top: '1rem' }).childs([
2024-09-05 22:46:21 +08:00
li.text('让事情变简单直观, 仅使用js代码, 而不必在 js/html/css 文件之间来回翻找'),
li.text('大幅提高代码信息密度, 灵感来自 pug/winicss/flutter, 减少布局与样式冗余'),
li.text('为dom对象添加链式操作方法, 使其返回值都是dom自身')
2024-06-27 14:44:29 +08:00
]),
2024-08-24 15:41:55 +08:00
new button({
textContent: '模态窗口 dialog',
onclick: event => {
document.body.appendChild(Dialog({
2024-09-06 01:08:14 +08:00
style: { width: '32rem', padding: '24px' },
2024-08-24 15:41:55 +08:00
children: [
2024-09-06 01:08:14 +08:00
div.childs([
h2.m_0.font_semibold.text('Are you absolutely sure?'),
p.mt_8.color('#71717a').text('This action cannot be undone. This will permanently delete your account and remove your data from our servers.')
]),
div.flex.justify_end.gap_8.childs([
button.text('Cancel'),
button.text('Delete'),
]),
2024-08-24 15:41:55 +08:00
]
}))
}
}),
2024-06-27 14:44:29 +08:00
// 三类参数
p.text(`
span 是一个类(class), 直接实例化 (new span()) 将创建一个 span 元素(DOM对象). 实例化时可以传递参数, 它对应DOM对象的属性.
span.m('2rem').p({ top: '2rem' }).text('Hello world!') 是一个链式操作, 每个链式操作都是DOM对象的方法缩写. 不同的是它返回的是DOM对象自身.
span.cursor_pointer.color_ppp.w(128).h(64).childs([span.text('Hello world!')]) 是预定义的链式操作, 在执行函数方法前的静态属性调用并没有实例化对象, 只是缓存了属性值. 当对象被实例化时, 静态属性会被应用到实例对象上. 而静态属性的语法对应 tailwindcss 的类名.
`)
]))
// 使用 js 文件作为组件管理代码
document.body.appendChild(div.cursor_pointer.color_ppp.w(128).h(64).childs([
2024-05-16 06:46:41 +08:00
span.m('2rem').p({ top: '2rem' }).text('Hello world!'),
2024-05-16 05:00:08 +08:00
new span({ textContent: 'Hello world!' }),
2024-05-15 22:38:07 +08:00
]))
2024-01-12 04:38:20 +08:00
2024-05-16 05:00:08 +08:00
fetch('/index.js').then(res => res.text()).then(text => {
2024-06-27 14:44:29 +08:00
text = text.replace(/from "\/main.js"/g, "from '@laniakeasupercluster/widgets'")
2024-09-05 22:30:01 +08:00
document.body.appendChild(pre.overflow_auto.p('2rem').bg('#ececec').text(text.substring(0, text.indexOf('fetch'))))
2024-05-16 05:00:08 +08:00
})