import { div, span, pre, h1, p, ul, li, button, createElement } from './main.js' import { Dialog } from './widgets/dialog.js' document.body.appendChild(div.absolute.t_2.r_2.bg_red_500.childs([ div.text('会话/账户') ])) // cursor-pointer overflow-clip hover:text-pink-500 document.body.appendChild(div.cursor_pointer.bg_red_500.overflow_clip.w_1000.childs([ h1.m_2rem.pt_2rem.text('Widgets!'), p.m('2rem').p({ top: '2rem' }).text('是什么, 为什么, 怎么做?'), ul.m('2rem').p({ top: '2rem' }).childs([ li.text('让事情变简单直观, 仅使用js代码, 而不必在 js/html/css 文件之间来回翻找'), li.text('大幅提高代码信息密度, 灵感来自 pug/winicss/flutter, 减少布局与样式冗余'), li.text('为dom对象添加链式操作方法, 使其返回值都是dom自身') ]), new button({ textContent: '模态窗口 dialog', onclick: event => { document.body.appendChild(Dialog({ children: [ new span({ textContent: 'Hello world!' }), new span({ textContent: 'Hello world!' }), ] })) } }), new span({ textContent: 'Hello world!' }), // 三类参数 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([ span.m('2rem').p({ top: '2rem' }).text('Hello world!'), new span({ textContent: 'Hello world!' }), ])) fetch('/index.js').then(res => res.text()).then(text => { text = text.replace(/from "\/main.js"/g, "from '@laniakeasupercluster/widgets'") document.body.appendChild(pre.overflow_auto.p('2rem').bg('#ececec').text(text.substring(0, text.indexOf('fetch')))) })