The Electron website has a new search engine that delivers instant results for API docs, tutorials, Electron-related npm packages, and more.
Learning a new technology or framework like Electron can be intimidating. Once you get past the quick-start phase, it can be difficult to learn best practices, find the right APIs, or discover the tools that will help you build the app of your dreams. We want the Electron website to be a better tool for finding the resources you need to build apps faster and more easily.
Visit any page on electronjs.org and you'll find the new search input at the top of the page.
The Search Engine
When we first set about adding search to the website, we rolled our own search engine using GraphQL as a backend. GraphQL was fun to work with and the search engine was performant, but we quickly realized that building a search engine is not a trivial task. Things like multi-word search and typo detection require a lot of work to get right. Rather than reinventing the wheel, we decided to use an existing search solution: Algolia.
Algolia is a hosted search service that has quickly become the search engine of choice among popular open source projects like React, Vue, Bootstrap, Yarn, and many others.
Here are some of the features that made Algolia a good fit for the Electron project:
- InstantSearch.js provides results as you type, usually in about 1ms.
- 输入容忍度 意味着您仍然会在输入 [
- Advanced query syntax enables
"exact quoted matches"and
- API clients are open source and with well-documented.
- Analytics tell us what people are searching for most, as well as what they're searching for but not finding. This will give us valuable insight into how Electron's documentation can be improved.
- Algolia is free for open source projects.
Sometimes you know what you want to accomplish, but you don't know exactly how to do it. Electron has over 750 API methods, events, and properties. No human can easily remember all of them, but computers are good at this stuff. Using Electron's JSON API docs, we indexed all of this data in Algolia, and now you can easily find the exact API you're looking for.
Trying to resize a window? 搜索 [
Electron has an ever-growing collection of tutorials to complement its API documentation. Now you can more easily find tutorials on a given topic, right alongside related API documentation.
Looking for security best practices? 搜索 [
There are now over 700,000 packages in the npm registry and it's not always easy to find the one you need. To make it easier to discover these modules, we've created
electron-npm-packages, a collection of the 3400+ modules in the registry that are built specifically for use with Electron.
Want alternatives to Electron's built-in IPC modules? 搜索 [
音乐] 或 [
If you've used GitHub's code search before, you're probably aware of its colon-separated key-value filters like
user:defunkt. We think this filtering technique is pretty powerful, so we've added an
is: keyword to Electron's search that lets you filter results to only show a single type:
People love keyboard shortcuts! The new search can be used without taking your fingers off the keyboard:
- / focuses the search input
- esc focuses the search input and clears it
- down moves to the next result
- up moves to the previous result, or the search input
- enter opens a result
We also open-sourced the module that enables this keyboard interaction. It's designed for use with Algolia InstantSearch, but is generalized to enable compatibility with different search implementations.
We want your feedback
If you encounter any issues with the new search tool, we want to hear about it!
The best way to submit your feedback is by filing an issue on GitHub in the appropriate repository:
- electron/electronjs.org is the Electron website. If you don't know where to file an issue, this your best bet.
- electron/algolia-indices is where all the searchable Electron data is compiled.
- electron/search-with-your-keyboard makes the search interface navigable by keyboard.
- algolia/instantsearch.js is the browser-side client that enables find-as-you-type search.