
或者带有两个辅助函数的普通 javascript?
在本文中,我将讨论如何使用 fusor 库开发可重用的 web 组件 以及这样做的好处。
这些组件可以组合成成熟的 web 应用程序,与使用 react、angular、vue、solid、svelte 等创建的应用程序相同。
fusor api 仅由两个 主要函数组成:
创建包装在特殊对象中的 dom 元素。更新包装在特殊对象中的 dom 元素。
加上一些很少使用的功能,例如:
立即学习“前端免费学习笔记(深入)”;
从特殊对象获取 dom 元素。
你不需要了解这个特殊物体的任何信息。
创建 dom 元素
通过 jsx 创建
import { getelement } from "@fusorjs/dom";const count = 0;// create via jsxconst message = seconds {count} elapsed
;document.body.append(getelement(message)); // get
我们使用了 create 和 get api 函数。
替代性非 jsx 创建
import { div } from "@fusorjs/dom/html";const message = div("seconds ", count, " elapsed"); // create
更新 dom 元素
import { getelement, update } from "@fusorjs/dom";let count = 0;const message = seconds {() => count} elapsed
; // createdocument.body.append(getelement(message)); // getsetinterval(() => { count += 1; update(message); // update}, 1000);
我们使用了update api 函数。它以递归方式更新 dom 元素及其所有子元素。它从函数结果中检索新值,使它们变得动态.子项、属性和属性都可以是动态的。
(toggle ? "on" : "off")} />
仅当新值
与当前值
不同时,才会发生 dom 更新。 设置参数
大多数时候,你会照常设置参数:
但是,有时您需要区分
属性
和属性。要指定它们的类型,您可以在它们的名称中添加 _a 或 _p 后缀:
要添加
事件处理程序
,您必须始终使用 _e 后缀:
"event handler"} />
还有其他类型,其中一些可以采取额外的
选项
以确保完整的w3c标准兼容性:
"event handler"} />
创建可重用组件
使用 fusor 的特殊对象组成您的组件。将状态和参数封装在函数内。将您的组件名称大写。
这是一个计数按钮组件的示例:
AI新媒体文章
专为新媒体人打造的AI写作工具,提供“选题创作”、“文章重写”、“爆款标题”等功能
75 查看详情
import { getelement, update } from "@fusorjs/dom";const countingbutton = (props) => { let count = props.count ?? 0; // init state const self = ( ); return self;};const app = () => ( );document.body.append(getelement(app()));
countingbutton 组件仅更新其自身 dom 元素的
部分
,而不影响应用程序的其余部分。一旦你完全理解了上述组件的工作原理,你就可以用稍微
更短
的方式重写它,同时达到相同的结果:
const countingbutton = ({ count = 0 }) => ( );
每个事件处理回调函数接收两个参数:标准事件对象和当前特殊对象。
再一次,如果您理解上面的示例,请查看同一组件的
最短
版本:
const countingbutton = ({ count = 0 }) => ( );
我们添加了 update 选项,用于在调用事件处理回调后刷新组件,这与前面的示例等效。
生命周期
在深入开发实际应用程序之前我们需要了解的最后一个方面是组件生命周期。
它仅由四个阶段组成:
创建组件连接到 dom更新 dom与 dom 断开
import { getElement, update } from "@fusorjs/dom";const IntervalCounter = ({ count = 0 }) => { console.log("1. Create the component"); return ( { console.log("2. Connect to the DOM"); const timerId = setInterval(() => { count++; update(self); console.log("3. Update the DOM"); }, 1000); return () => { clearInterval(timerId); console.log("4. Disconnect from the DOM"); }; }} > Since mounted {() => count} seconds elapsed
);};const instance = ;const element = getElement(instance);document.body.append(element);setTimeout(() => element.remove(), 15000);
mount 属性有一个函数,当组件被添加到 dom 时运行。该函数采用一个参数:当前的特殊对象。它还可以返回另一个在组件从 dom 中删除时运行的函数。
我们完全控制生命周期的这四个阶段。这让我们可以使用自定义的
异步
或并发方法来创建、更新和比较组件,并考虑不同的策略和动画帧。 教程到此结束
从本教程中可以看出,fusor 简单、简洁、明确。大多数时候,您只会使用它的
两个
api 函数。然而,它在需要时也提供了很多控制和灵活性。所以,回答标题中的问题,fusor 是一个小型 javascript 库,不是框架,但它可以达到与其他框架相同的结果。
开始编码
以上所有示例都可以在 codesandbox 上找到。
另外,请查看 svg 模拟时钟示例。
这是一个真实世界的应用程序。
样板入门项目:
javascript 入门typescript 入门 谢谢
以上就是新的前端框架?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/461059.html
赞 (0)
打赏
微信扫一扫
支付宝扫一扫
相关推荐
-
Go语言可以有效集成Microsoft SharePoint,主要通过两种途径:一是利用SharePoint提供的RESTful API进行数据交互,Go的标准HTTP客户端库即可轻松实现;二是通过SharePoint应用模型开发自托管应用,这种模型支持使用包括Go在内的任何语言编写后端逻辑。 1.…
-
JavaScript原生无生命周期钩子,这是Vue、React等框架为组件设计的机制;Vue按创建、挂载、更新、卸载四阶段提供对应钩子,React类组件有明确生命周期方法,函数组件则通过useEffect模拟,其核心价值在于精准控制执行时机以避免DOM操作错误和内存泄漏。 JavaScript 本身…
-
修复“bug:net::err_connection_refused”后端代码中的错误 在开发前后端分离项目时,使用vue2前端和fastapi后端,前端希望通过“http://10.96.67.161:8081/uploadimg/”接口传输图片给后端,但遇到了“post http://10.96…
-
最近我发布了一个 npm 包,其使命如标题所示:让项目只需一行代码即可响应! 我与您分享响应式应用程序 [beta] 包 我花了几年时间尝试和开发这项技术,目前包括: 动态设置 html 标签字体大小(通过 js 脚本),考虑:(1) 屏幕分辨率和 (2) 浏览器字体大小(用于网络可访问性)将像素定…
-
H5环境下EXCEL和Word文件在线预览技术详解 在如今的Web应用中,在线预览文档功能至关重要,尤其对于需要处理大量文件的企业应用。本文将介绍两种无需插件,直接在浏览器中预览EXCEL和Word文件的方法。 企业对在线文档预览的需求日益增长,以提高效率和协同性。下面我们探讨两种有效的H5在线预览…
-
根据小程序实现自动切换语言 对于多语言环境的小程序,如何自动切换语言是一个常见问题。 方法一:根据用户定位 这种方法基于用户定位来获取所在国家,并根据国家对应语言设置。然而,这种方法存在一定的局限性,如用户可能不会允许位置共享。 方法二:通过 wx.getsysteminfo 这是微信官方提供的 a…
-
webview2 无法接收打包 vue 项目发送的数据 在使用 webview2 嵌入 vue 项目时,开发者可能会遇到无法接收 c# 传输的数据的问题。要解决此问题,首先需要检查 webview2 控件加载的 html 页面的正确性。 一般来说,如果在加载独立的 html 页面(例如 test.h…
-
vue.js前端生成word文档并插入分页符的难题 许多开发者希望在Vue.js前端直接将HTML转换为包含分页符的Word文档。本文分析实现此目标的方法以及面临的挑战。 用户尝试使用page-break-after: always属性(或其替代属性break-after)在生成的Word文档中添加…
-
正确使用表单标签与属性、支持“记住我”功能、避免破坏自动填充机制、测试浏览器兼容性可实现稳定自动填充。1. 使用标准input类型并设置autocomplete属性为username和current-password;2. 登录成功后通过localStorage保存用户名,页面加载时恢复;3. 避免…
-
本文深入探讨了在javascript中动态生成html链接时,如何正确地将变量(尤其是url)嵌入到`href`属性中。通过分析常见的错误,即混淆javascript的模板字面量与框架特有的模板语法,文章详细演示了使用es6模板字面量`${}`进行字符串插值的正确方法,确保动态链接能够被浏览器正确解…
-
Vue自定义指令意外生效之谜:深入探讨 本文探讨一个常见的Vue.js开发问题:自定义指令在未绑定目标元素上生效的原因。我们分析一个案例,解释这种现象背后的机制,并提供解决方案。 案例描述 我们创建了一个全局自定义指令 validateNumber,用于限制输入框只能输入数字: Vue.direct…
-
menu和menuitem标签虽在HTML5中被设计用于创建上下文菜单和工具栏,但因主流浏览器支持极差(仅Firefox部分支持),实际应用受限;现代开发普遍采用JavaScript结合ARIA属性(如role=”menu”、aria-haspopup等)构建可访问、可定制的…
-
本文将指导您如何利用vuetify的组件快速搭建一个轻量级的wysiwyg(所见即所得)富文本编辑器。通过结合contenteditable特性和vuetify的v-btn-toggle等组件,我们可以轻松实现文本加粗、斜体、下划线等基础格式化功能,从而为您的应用添加强大的文本编辑能力,同时保持代码…
-
推荐从Django开始开发Python网页版后台管理系统,1. 使用Django自带admin模块可快速搭建基础后台;2. 定义数据模型并注册到admin,通过makemigrations和migrate生成数据库结构;3. 创建超级用户后即可登录管理界面;4. 在admin.py中自定义列表展示、…
-
Android WebView与JavaScript命名规范兼容性问题分析及解决方案 JavaScript代码的命名规范至关重要。最佳实践建议使用字母、数字、下划线和美元符号,首字符不能为数字。然而,近期在集成pdfjs-dist库时,我们发现一个兼容性问题:在Chrome浏览器运行正常的代码,在A…
-
异步上下文追踪的核心在于重建被事件循环割裂的调用链,通过AsyncLocalStorage、Zone.js或手动传递上下文等方案,将请求ID、用户信息等关键数据贯穿异步流程,使错误堆栈不再孤立,从而精准定位问题根源。 在JavaScript的复杂世界里,异步上下文在错误追踪中扮演着至关重要的角色,它…
-
Vue Hooks:正确渲染异步数据到模板 在Vue Hooks中,将异步数据渲染到模板经常会遇到数据更新后视图未更新的问题。本文将分析原因并提供解决方案。 问题示例: 假设我们使用axios获取数据,并用响应式变量tableData存储: 立即学习“前端免费学习笔记(深入)”; import { …
-
减小JavaScript包体积可提升加载速度与用户体验,核心方法包括精简代码、按需加载和优化传输。首先检查依赖,移除未使用包,选用轻量库如dayjs替代moment.js,并利用Tree Shaking只引入必要代码。其次通过动态import实现路由级懒加载,将第三方库单独分包,结合splitChu…
-
uniapp小程序:巧妙获取事件对象中的自定义属性 在UniApp小程序开发中,我们经常需要在事件处理函数里访问自定义属性。例如,点击一个带有自定义属性的按钮,获取该属性值。然而,直接从事件对象中获取这些属性值时,可能会遇到问题。本文将深入探讨这个问题,并提供有效的解决方案。 问题:无法直接获取自定…
-
动态添加时间范围的逻辑实现 需求: 开始时段选择后,结束时段小于开始时段的值置灰不能选择。新增时间段时,已选时间段置灰不能选择。 逻辑实现: 父组件(VueTemplateIndex): 初始化时,将数据进行行列合并操作。新增数据时,使用 deepClone 深拷贝当前数据,并在子组件中编辑。 子组…