首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何规范发布一个现代化的 NPM 包?

umd 是“Universal Module Definition”的缩写,它可以 标签中执行、被 CommonJS 模块加载加载、被 AMD 模块加载加载。...外置框架 不要将 React、Vue 等框架打包在你的库中 当构建的库依赖某个框架(例如 React、Vue 等),或是作为另一个库的插件,你可能需要将框架配置到“externals”中。...如果 CSS 只是你的库的一部分(例如,具有默认样式的组件库),那么最好将 CSS 按组件分离单独构建产出,使用相应的组件时按需导入。这方面的一个例子是 react-component。...允许你根据不同的条件(你可以定义)去选择那个文件是被导入的,例如“文件是被 import 还是被 require?...如果你有一个 "development" 和一个 "production" 的产出(例如,你有一些警告 development 产出中有但在 production 产出中没有),那么你可以通过 exports

2.1K20

现代 JavaScript 库打包指南

umd 是“Universal Module Definition”的缩写,它可以 标签中执行、被 CommonJS 模块加载加载、被 AMD 模块加载加载。...外置框架 不要将 React、Vue 等框架打包在你的库中 当构建的库依赖某个框架(例如 React、Vue 等),或是作为另一个库的插件,你可能需要将框架配置到“externals”中。...如果 CSS 只是你的库的一部分(例如,具有默认样式的组件库),那么最好将 CSS 按组件分离单独构建产出,使用相应的组件时按需导入。这方面的一个例子是 react-component。...允许你根据不同的条件(你可以定义)去选择那个文件是被导入的,例如“文件是被 import 还是被 require?...如果你有一个 "development" 和一个 "production" 的产出(例如,你有一些警告 development 产出中有但在 production 产出中没有),那么你可以通过 exports

2.3K20
您找到你想要的搜索结果了吗?
是的
没有找到

渐进式React

熟悉 React 内部原理的同学知道,React 生命周期中有个 Commit 阶段,React DevTools Profiler 会以每次 commit 维度记录渲染相关信息,右侧进行展示。...另外如果需要在滚动场景做异步加载的同学,可以了解下 react-loadable-visibility 。...这里主要是安利 Workbox 这个工具包,它能让我们更简单使用 Service Worker,具体细节不做展开, PWA 的浪潮中,你的站点值得拥有。...,但可以不用再去编辑复杂的 CSS 文件了,如果你不想自己维护一套样式规范,可以直接用开源的 Tachyons 方案。...(真实情况是 recompose 的作者加入了 React Team,并推出了 Hooks) 虽然 Hooks 的定位是解决代码架构问题,但确实也加载性能方面做出了贡献。

2.1K70

现代 JavaScript 库打包指南

umd 是“Universal Module Definition”的缩写,它可以 标签中执行、被 CommonJS 模块加载加载、被 AMD 模块加载加载。...外置框架 不要将 React、Vue 等框架打包在你的库中 当构建的库依赖某个框架(例如 React、Vue 等),或是作为另一个库的插件,你可能需要将框架配置到“externals”中。...如果 CSS 只是你的库的一部分(例如,具有默认样式的组件库),那么最好将 CSS 按组件分离单独构建产出,使用相应的组件时按需导入。这方面的一个例子是 react-component。...允许你根据不同的条件(你可以定义)去选择那个文件是被导入的,例如“文件是被 import 还是被 require?...如果你有一个 "development" 和一个 "production" 的产出(例如,你有一些警告 development 产出中有但在 production 产出中没有),那么你可以通过 exports

88330

现代 JavaScript 库打包指南

umd 是“Universal Module Definition”的缩写,它可以 标签中执行、被 CommonJS 模块加载加载、被 AMD 模块加载加载。...如果 CSS 只是你的库的一部分(例如,具有默认样式的组件库),那么最好将 CSS 按组件分离单独构建产出,使用相应的组件时按需导入。这方面的一个例子是 react-component。...允许你根据不同的条件(你可以定义)去选择那个文件是被导入的,例如“文件是被 import 还是被 require?...字段用于兜底,没有任何条件匹配时使用。...如果你有一个 "development" 和一个 "production" 的产出(例如,你有一些警告 development 产出中有但在 production 产出中没有),那么你可以通过 exports

85810

【Hybrid开发高级系列】WebPack模块化专题

2.2.2 publicPath         publicPath参数表示的是一个URL路径(指向生成文件的根目录),用于生成css/js/图片/字体文件等资源的路径,以确保网页能正确加载到这些资源...条件值(condition)可以是一个字符串(某个资源的文件系统绝对路径),可以是一个函数(官方文档里是有这么写,但既没有示例也没有说明,我也是醉了),可以是一个正则表达式(用来匹配资源的路径,最常用,...,最后,还可以是一个数组,数组的元素可以为上述三种类型,元素之间为与关系(既必须同时满足数组里的所有条件)。需要注意的是,loader是可以接受参数的,方式类似于URL参数,形如'css?...3、各个页面中,先加载Dll文件,再加载业务代码文件。...了解过code splittiog的同学便会知道,我们有些代码加载页面的时候不会被使用时,使用code splitting,可以实现将这部分不会使用的代码分离出去,独立成一个单独的文件,实现按需加载

32750

【实战】快来和我一起开发一个在线 Web 代码编辑器

onTabClick('js') }} /> 接着,我们使用三元运算符有条件显示选项卡的内容: ... return ( <div className...它由我们在上面导入的 CodeMirror 的 CSS 文件提供。 options 这是一个具有我们希望编辑器具有的不同功能的对象。 CodeMirror 中有许多令人惊叹的选项。...使用 iframe 时,我们可以页面上嵌入外部网页或呈现指定的 HTML 内容。 要加载和嵌入外部页面,我们将使用 src 属性。...这样可以让用户清楚知道他们当前正在使用哪个编辑器,从而提高可访问性。 你可能希望编辑器占用比我们这里更多的屏幕空间。 你可以尝试的另一件事是通过单击停靠在侧面某处的按钮来弹出 iframe。...目前,我们可以加载的多个主题中切换编辑器组件的主题,但页面的总体主题保持不变。 你可以让用户整个布局的深色和浅色主题之间切换。 这将有利于可访问性,减轻人们长时间看明亮的屏幕对眼睛的压力。

45320

开发一个在线 Web 代码编辑器,如何?今天来教你!

onTabClick('js') }} /> 接着,我们使用三元运算符有条件显示选项卡的内容: ... return ( <div className...它由我们在上面导入的 CodeMirror 的 CSS 文件提供。 options 这是一个具有我们希望编辑器具有的不同功能的对象。CodeMirror 中有许多令人惊叹的选项。...使用 iframe 时,我们可以页面上嵌入外部网页或呈现指定的 HTML 内容。要加载和嵌入外部页面,我们将使用 src 属性。...这样可以让用户清楚知道他们当前正在使用哪个编辑器,从而提高可访问性。 你可能希望编辑器占用比我们这里更多的屏幕空间。你可以尝试的另一件事是通过单击停靠在侧面某处的按钮来弹出 iframe。...目前,我们可以加载的多个主题中切换编辑器组件的主题,但页面的总体主题保持不变。你可以让用户整个布局的深色和浅色主题之间切换。这将有利于可访问性,减轻人们长时间看明亮的屏幕对眼睛的压力。

11.8K30

长期维护更新,前端面试题

如果你的 Banner、插件和布局样式是使用 CSS 保存在不同的文件内,那么,访问者的浏览器每次访问都会加载很多文件。...合理设置浏览器缓存,能让浏览器自动存储某些文件,以便加快传输速度。此方法的配置可以直接在源服务器的配置文件中完成。...7.压缩文件 虽然许多 CDN 服务可以压缩文件,但如果不使用 CDN,您也可以考虑源服务器上使用文件压缩方法来改进前端优化。 文件压缩能使网站的内容轻量化,更易于管理。...而 React Component 则是可以接收参数输入并且返回某个React Element的函数或者类。更多介绍可以参考React Elements vs React Components。...不过实际开发中我们并不提倡使用非受控组件,因为实际情况下我们需要更多的考虑表单验证、选择性的开启或者关闭按钮点击、强制输入格式等功能支持,而此时我们将数据托管到 React 中有助于我们更好以声明式的方式完成这些功能

2.4K41

React 设计模式 0x4:样式

React 中有不同的方法来实现这一点。 # 样式化类型 React 和网站或 Web 应用程序中,有不同的样式化应用程序的方式。... ); } export default Example; 优点: 无需额外的文件,容易编写 浏览器可以快速加载和应用样式 缺点: 无法重用样式 容易被覆盖 难以维护... ); } export default Example; 优点: 编写简单 保持组件干净,不会混合样式和组件 可以重用样式 缺点: 加载速度慢,因为需要加载额外的文件...CSS,因为 React 应用程序中编写起来更快并且易于维护。...# BEM BEM 是一种命名约定,它可以帮助您更好组织样式。BEM 代表块(block)、元素(element)和修饰符(modifier),它们可以组合在一起,用于将大型界面拆分为独立的块。

1.3K20

指尖前端重构(React)技术分析报告

这里值得一提的是,React-router配合webpack可以实现代码的按需加载。...通过router中写require.ensure代码并在webpack中相应修改配置即可将js分成多个文件需要时加载对应的js文件,实现按需加载。...这里涉及到脚手架create-react-app 添加对scss的支持,命令行执行安装,并在package.json的scripts中添加watch-css指令,将原css文件改为scss文件,然后最外层添加...React严格执行组件技术,组件化不仅方便重用,同样可以将一个页面清晰分割为几个部分最后放入一个父组件展示,因为jsx技术将js和html放在了一起,分割后每个部分有自己的功能逻辑与页面展示,这样更加清晰易维护...而现在只要在React-router统一配置好路由,实质上是往某个组件跳转,不存在跳转路径的限制。 Constants文件夹下存放各种常量,比如各种接口路径。

5.4K30

webpack 代码分离快速指北

⭐️ 更多前端技术和知识点,搜索订阅号 JS 菌 订阅 分离代码文件 在此之前,首先要知道经常配置的 output 中有关 filename 和 chunkFilename 的区别;简单来说 entry...定义的入口文件走的就是 filename 配置项,入口文件内部引入的通常情况下是 chunk,走 chunkFilename 的配置 所以很多时候分离代码文件就是将不同的 chunk 分离开来,生产环境中有利于浏览器缓存...; reuseExistingChunk: 表示可以使用已经存在的块,即如果满足条件的块已经存在就使用已有的,不再创建一个新的块。...,加载页面时虽然只需要加载一个 JS 文件,但代码一旦改变,用户访问新的页面时就需要重新加载一个新的 JS 文件。...还可以根据入口的不同,来分别打包 css 文件,文档已经讲的很详细了,这部分比较简单可以直接戳文档 https://webpack.js.org/plugins/mini-css-extract-plugin

1.1K10

github 项目搜索技巧-让你更高效精准搜索项目

github 搜索技巧 参考自 B站 up 主 CodeSheep 的视频【如何高效在网上找开源项目做!...-12-20 效果:加了限制条件后,查出来的项目数有了明显的减少 ?...自己看官方文档(感觉用不到,就不整理了吧):【找仓库中的某个文件】、【 github 上查找代码片段】 查找某个用户或组织的项目 限定词 案例 user:USERNAME user:1335951413...(支持大于小于区间等) pushed:YYYY-MM-DD css pushed:>2013-02-01 查出仓库中包含 css 关键字,并且 2013年1月 之后更新过的项目 language:LANGUAGE...使用指南 自己灵活的使用限定词和辅助限定词写出一套规则即可查出你想要的项目 他们的位置先后、数量都无所谓,加上只是多了一个条件 练习案例 常用到的其实有就是这些,上面的还是太多了,你有那个需求,又找不到方式的时候可以查查看

1.1K31

React Native调试心得

Developer Menu中有Reload选项,单击Reload让React Native重新加载js。...该工具可以有效追踪布局问题,设置 JavaScript 断点并可深入理解代码的最优化策略。...Resource 面板:用于查看当前页面所请求的资源文件,如 HTML,CSS 样式文件等。 Audits 面板:用于优化前端页面,加速网页加载速度等。...编辑断点(Edit Breakpoint): 通过该功能你可以创建一个条件断点,你也可以边栏(gutter line) 右键并选择添加条件断点(Add Conditional Breakpoint)...输入框中,输入一个可解析为真或假的表达式。仅当条件为真时,执行会在此暂停。  ? 心得:如果你想让程序在某处从来都不要暂停,可以编辑一个条件永远为false的条件断点。

5K70

QQ音乐商业化Web团队前端工程化实践总结

js文件需要进行网络请求,而网络请求的耗时是不可预期的,这使得CommonJS同步加载模块的机制浏览器端并不适用,我们不能因为要加载某个模块js而一直阻塞浏览器继续执行下面的代码。...中有详细的介绍,可以结合这份性能测试报告综合评估ES6node以及各种浏览器环境下的执行效率对比。...与Web Component不同的是React中的HTML标签运行在Virtual DOM中,非标准的浏览器环境,React的这种机制可以更好实现跨平台,Web Component则更有可能实现浏览器大统一...[开发流程] UI组件开发和文档 我们选择react-styleguide作为UI组件开发调试工具以及文档生成器,这是一个组件的MD文件示例: ### 组件式引入 - 可以提前插入dom结构,如果浮层中有图片的话会先加载...### 组件式引入 - 可以提前插入dom结构,如果浮层中有图片的话会先加载; - 属性中的 `visible` 控制组件是否可见。 import Button from '../..

4.2K112

CSS Modules VS. styled-components,哪个才是解决 CSS 不足之处的更好方案?

styld-components 是一种 CSS-in-JS 的优秀实践,通过 JS 来声明、抽象样式来提高组件的可维护性,组件加载时动态加载样式,并且动态生成类名避免命名冲突和全局污染。...组合可以发生在同一个 CSS 文件的不同类之间,也可以发生在不同 CSS 文件的不同类之间。后者可以理解为 CSS 中加入了模块机制。...(CSS Modules 通过哈希编码局部类名实现这一点) CSS 更容易移除:使用 styled-components 可以很轻松知道代码中某个 class 在哪儿用到,因为每个样式都有其关联的组件...但是,如果您在一个组件中有多种按钮,例如 default、primary、warn 等,则可以样式字符串中使用带条件的插值。...这也不是一个开始使用 styled-components 的充分理由; 虽然 styled-components 可以利用 props 对组件进行有条件的样式设置,这很符合 React 体系,并且利用了

7.3K72
领券