Web Components 是一种可以让开发者创建可重用、可扩展且与 Web 平台本身无关的 UI 组件的标准。Web Components 技术的出现,使得不必被静态页面和 JavaScript 插件所束缚,开发者可以创建更为强大和灵活的组件,这一技术的应用也已经在很多现代化的 Web 应用程序的构建中得到了广泛的应用。
在本篇文章中,我们将详细介绍 Web Components 的构成及使用方法,并配以示例代码,帮助开发者理解 Web Components 的组成、工作方式以及如何使用它们构建出更为标准化的 Web 应用。
Web Components 的组成
Web Components 由三个重要的技术组成部分,这三个部分分别为:
Custom Elements:这是一种新的 DOM 元素,可以通过它来定义自己的 HTML 标签名称,并定义该标签名称对应的 DOM 行为。
Shadow DOM:这是一种可以将一个 DOM 树的一部分隐藏(封装)起来不被外部访问的技术,是 Web Components 实现增强封装固有特点的核心部分。
HTML Templates:这是一种可以让开发者先定义标签结构,只有在需要的时候才将它实例化的技术。
通过使用这三个 Web Components 的技术组成部分,我们可以通过组合来创建更具有灵活性、维护性和易用性的 UI 组件,且能够在不同项目之间方便的进行分享和复用。
如何使用 Web Components
在这一小节中,我们将介绍如何使用上述三个 Web Components 技术组成部分,以及如何设计和实现一个简单的登录组件来帮助开发者更好的理解如何使用这些技术。
使用 Custom Elements 定义登录组件
在 HTML 中,我们在创建自定义标签时,可以使用如下所示的方式来操作 Custom Elements 技术:
-- -------------------- ---- ------- -------- ----- --------- ------- ----------- - ------------- - -------- ----- -------- - -------------------------------------- ----- --------------- - ----------------- ----- ---------- - ------------------------ --------- -------------------------------------------------------- ----------------- - --------------------------------------------- ------------------ - ------------------------------------------------- ------------------ - ------------------------------------------------- ------------------------------------------- ----- -- - ----------------------- ----------------------- --- - ----------------- - -- --- - - ----------------------------------- ----------- --------- --------- ---------------- ------ ----- ------ --------------------------------- ------ ------------------- --------------- --------- ------ ----- ------ -------------------------------- ------ ------------------- --------------- --------------- --------- ------ ------- --------------- ------------------------- ------- ----------- -------------------------
在上述示例代码中,我们首先定义了一个 LoginForm
类来表示我们的登录组件。接着,我们在 constructor
方法中使用 Shadow DOM 技术来创建一个阴影树,然后将我们通过 template
标签的内容克隆并附加到了 Shadow DOM 中。最后,我们通过 querySelector
方法来获得三个输入框(用户名、密码、提交按钮的元素),并监听 submitButton
对象的单击事件,以便在单击时调用 submitLoginForm
方法(此方法将通过网络协议来提交表单数据)。
最后,我们通过 customElements.define
方法来为 login-form
标签注册一个自定义元素。这里要注意,自定义元素的名称可以任意指定,但一定要确保名称不会与 HTML 5 标准中已有的标记名称相同。
使用 Shadow DOM 隐藏组件的实现细节
前面的例子中,我们使用 Shadow DOM 技术来创建内部的阴影 DOM 树。通过阴影 DOM 树,我们可以将组件的所有实现细节封装起来,这对于复杂组件的维护和开发是非常有帮助的。
举个例子,我们构建了一个特别的输入组件,它可以满足有一些特别的需求,但是我们不希望在所有页面上都将其实现细节公开。为了达到这个目的,我们可以使用如下方式构建该组件:
-- -------------------- ---- ------- -------- ----- ------------ ------- ----------- - ------------- - -------- -- -- ---------- ----- ---------- - ------------------------ --------- -------------------- - - ------- ----- - -------- ------------ - ----- - ------------- ---- - ----- - ---------- ----- -------- --- ---- -------------- ---- ------- ----- ----------- - - --- --------------- ----------------- ----- - -------- ------- ----- ----------------- ------- -------- -- -- -- --- -- ----------------- - --------------------------------------- ---------------- - --------------------------------------- - ------------------- - -- ------- ------------------------------------------- ----- -- - ---------------------- --------------------- - -------- ----- ------- - ------ ----------------------- - ---- --- - ------ --- -------------------- - ------ --------- - ------------------------------ --------- --------- - -- ----- --- ------ -- -------- --- --------- - -------------------------- - --------- - - - -------------------------------------- -------------- --------- -------------- --------- -------------------------------------
在这个特殊输入组件中,我们通过 Shadow DOM 技术来包装其样式,使其不受外部的样式影响。同时,我们可以通过 connectedCallback
方法来绑定输入框事件,借由 CustomEvent
对象来向外派发 change
事件。最后,观察我们的组件输出结果,我们可以看到示例中使用了 icon
和 placeholder
字段的标记语言配置,而这些字段细节都已被封装在组件内部。
使用 HTML Templates 实现模板复用
无独有偶,HTML Templates 技术是一个非常有用的技术,它可以帮助开发者声明常用组件,而不必重复编写重复的 HTML 或 JavaScript 代码。
HTML Templates 技术使得我们可以先定义某些 HTML 标记,然后将它们作为模板来在客户端实例化,这大大方便了前端组件的复用,从而可以提高应用的开发效率,如下示例代码:
-- -------------------- ---- ------- -------- ----- -------- ------- ----------- - ------------- - -------- ----- -------- - ------------------------------------- ----- --------------- - ----------------- ----- ---------- - ------------------------ --------- -------------------------------------------------------- - - ---------------------------------- ---------- --------- --------- --------------- ----- ----------------- ---- ------ ----------- ---------- ------ ----------- ---------- ------ ----------- ---------- ----- ------ ----------- ---- --- -------- -- --- -----------------------
在这个示例中,我们使用 HTMLTemplates
技术将一些常用的 HTML 标记片段封装到了一个 template
标记里面。通过这个标记,我们可以在前端页面使用一个自定义的标签(news-feed
),将之前封装在组件内的 HTML 片段注入页面中,以达到快速反复使用、维护和修改的目的。
结论
在这篇文章中,我们详细介绍了 Web Components 的组成部分以及它们的优势和限制。通过示例代码,我们还成功地演示了如何使用 Custom Elements、Shadow DOM 和 HTML Templates 等 Web Components 技术来创建自定义组件。
当然,正如任何技术一样,Web Components 技术也并不是一个适合所有类型的应用程序的解决方案。然而,对于复杂的应用程序、模块化的设计和搭建、以及一些大规模多人协作的项目中,它可以成为 Web 应用开发者们的关键利器。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6738b037317fbffedf121ef5