《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的Skate 是一个功能性的反应式抽象 Web 组件标准作为一组包,您可以使用 React、Preact 和 LitHTML 等流行的视图库编写小型、快速和可扩展的 Web 组件。
启动和运行的最简单方法是从预先配置的元素开始,例如@skatejs/element-lit-html.
npm i @skatejs/element-lit-htmlimport Element, { html } from '@skatejs/element-lit-html';
export default class extends Element {
static get props() {
return {
name: String
};
}
render() {
return html`
Hello, ${this.name}!
`;
}
}cli
有一个 CLI 可以帮助您启动并运行:https://skatejs.netlify.com/packages/cli.
$ npm i -g @skatejs / cli
$skatejs填充物
Skate建立在 自定义元素和 影子 DOM标准。它能够在没有 Shadow DOM 的情况下运行——这只是意味着您不会对组件的 HTML 或样式进行任何封装。这也意味着您可以提供一种投射内容的方式(即
尽管大多数现代浏览器都支持这些标准,但有些仍然需要 polyfill 来为它们实现缺失或不一致的行为。
浏览器支持
Skate 支持所有的常青树和 IE11,并受制于 polyfills 的浏览器支持矩阵。
一套支持Web 组件规范的 polyfill:
对于需要它的浏览器,还包括一些小的 polyfill:
安装 polyfill
npm install @webcomponents/webcomponentsjs您还可以从 CDN 加载代码,例如 unpkg:https ://unpkg.com/@webcomponents/webcomponentsjs@^2/
使用webcomponents-bundle.js
包含所有的webcomponents-bundle.jsweb 组件 polyfills,适用于任何支持的浏览器。所有的 polyfill 代码都将被加载,但每个 polyfill 仅用于基于特征检测。该捆绑包包括自定义元素、Shady DOM/CSS 和通用平台 polyfill(例如 ES6 Promise、可构造事件等)(Internet Explorer 11 需要)和模板(IE 11 和 Edge 需要)。
使用webcomponents-bundle.js起来非常简单,但它会加载大多数现代浏览器不需要的代码,从而减慢页面加载速度。为获得最佳性能,请使用webcomponents-loader.js.
这是一个例子:
使用webcomponents-loader.js
这webcomponents-loader.js是一个客户端加载器,它使用特征检测动态加载最小的 polyfill 包。
webcomponents-loader.js可以根据您的需要同步或异步加载。
内联
如果你已经内联了 的源webcomponent-loader.js,那么你应该指定window.WebComponents.root作为加载 polyfill 的根。例如:
此属性用于构建所选捆绑包的 URL,因此您应该只将其设置为不受用户控制数据影响的值。如果强制执行受信任类型,则此属性应为TrustedScriptURL.
同步
同步加载时,webcomponents-loader.js其行为类似于webcomponents-bundle.js.
将加载适当的包document.write()以确保 WebComponent polyfill 可用于后续脚本和模块。
这是一个例子:
异步
当使用该defer属性异步加载时,polyfill 包将被异步加载,这意味着依赖于 webcomponents API 的脚本和模块必须使用WebComponents.waitFor函数加载。
该WebComponents.waitFor函数将回调函数作为参数,并在加载 polyfill 包后评估该回调。
回调函数应该加载需要 polyfills 的脚本(通常是通过import('my-script.js')),并且应该返回一个在所有脚本都加载后解析的 promise。
这是一个例子:
—END—
开源协议:MIT license
开源地址:https://github.com/skatejs/skatejs
| 留言与评论(共有 0 条评论) “” |