mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-13 22:30:37 +08:00
translated
This commit is contained in:
parent
c4e43a77bd
commit
f69bea1f14
@ -1,145 +0,0 @@
|
|||||||
[#]: subject: (Build a static website with Eleventy)
|
|
||||||
[#]: via: (https://opensource.com/article/21/6/static-site-builder)
|
|
||||||
[#]: author: (Nwokocha Wisdom https://opensource.com/users/wise4rmgod)
|
|
||||||
[#]: collector: (lujun9972)
|
|
||||||
[#]: translator: (geekpi)
|
|
||||||
[#]: reviewer: ( )
|
|
||||||
[#]: publisher: ( )
|
|
||||||
[#]: url: ( )
|
|
||||||
|
|
||||||
Build a static website with Eleventy
|
|
||||||
======
|
|
||||||
Eleventy is a JavaScript-based alternative to Jekyll and Hugo for
|
|
||||||
building static websites.
|
|
||||||
![Digital images of a computer desktop][1]
|
|
||||||
|
|
||||||
A static site generator is a tool that generates a full, static HTML website based on raw data and a set of templates. It automates the task of coding individual HTML pages and gets those pages ready to serve to users. Because the HTML pages are prebuilt, they load very quickly in users' browsers.
|
|
||||||
|
|
||||||
Static sites work particularly well for documentation, too, because static sites are easy to scale, and they're an easy way to generate, maintain, and deploy your project's documentation. For these reasons, organizations often use them to document application programming interfaces (APIs), database schemas, and other information. Documentation is an important part of software development, design, and other aspects of tech. All codebases require some form of documentation, with options ranging from a simple README to full documentation.
|
|
||||||
|
|
||||||
### Eleventy: A static site generator
|
|
||||||
|
|
||||||
[Eleventy][2] (11ty) is a simple static site generator and an alternative to [Jekyll][3] and [Hugo][4]. It's written in JavaScript and transforms a directory of templates (of varying types) into HTML. It's also open source, released under the MIT License.
|
|
||||||
|
|
||||||
Eleventy works with HTML, Markdown, Liquid, Nunjucks, Handlebars, Mustache, EJS, Haml, Pug, and JavaScript Template Literals.
|
|
||||||
|
|
||||||
Its features include:
|
|
||||||
|
|
||||||
* Easy setup
|
|
||||||
* Supports multiple template languages (e.g., Nunjucks, HTML, JavaScript, Markdown, Liquid)
|
|
||||||
* Customizable
|
|
||||||
* Based on JavaScript, which is familiar to many web developers and easy for new users to learn
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### Install Eleventy
|
|
||||||
|
|
||||||
Eleventy requires Node.js. On Linux, you can install Node.js using your package manager:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ sudo dnf install nodejs`
|
|
||||||
```
|
|
||||||
|
|
||||||
If your package manager doesn't have Node.js available, or if you're not on Linux, you can [install it][5] from the Node.js website.
|
|
||||||
|
|
||||||
Once Node.js is installed, use it to install Eleventy:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ npm install -g @11ty/eleventy`
|
|
||||||
```
|
|
||||||
|
|
||||||
That's it!
|
|
||||||
|
|
||||||
### Build a static site for your documentation
|
|
||||||
|
|
||||||
Now you can start using Eleventy to build your static documentation site. Here are the steps to follow.
|
|
||||||
|
|
||||||
#### 1\. Create a package.json file
|
|
||||||
|
|
||||||
To install Eleventy into your project, you need a package.json file:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ npm init -y`
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2\. Install Eleventy into package.json
|
|
||||||
|
|
||||||
Install and save Eleventy into your project's `package.json` by running:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ npm install-save-dev @11ty/eleventy`
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 3\. Run Eleventy
|
|
||||||
|
|
||||||
Use the `npx` command to run your local project's version of Eleventy. After you verify installation went as expected, try to run Eleventy:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ npx @11ty/eleventy`
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 4\. Create some templates
|
|
||||||
|
|
||||||
Now run two commands to create two new template files (an HTML and a Markdown file):
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
$ cat << EOF >> index.html
|
|
||||||
<!doctype html><html>
|
|
||||||
<head>
|
|
||||||
<title>Page title</title>
|
|
||||||
</head><body>
|
|
||||||
<p>Hello world</p>
|
|
||||||
</body></html>
|
|
||||||
EOF
|
|
||||||
$ echo '# Page header' > index.md
|
|
||||||
```
|
|
||||||
|
|
||||||
This compiles any content templates in the current directory or subdirectories into the output folder (which defaults to `_site`).
|
|
||||||
|
|
||||||
Run `eleventy --serve` to start a development web server.
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ npx @11ty/eleventy-serve`
|
|
||||||
```
|
|
||||||
|
|
||||||
Open `http://localhost:8080/README/` in the web browser of your choice to see your Eleventy output.
|
|
||||||
|
|
||||||
Then upload the files in `_site` to your web server to publish your site for the world to see.
|
|
||||||
|
|
||||||
### Try Eleventy
|
|
||||||
|
|
||||||
Eleventy is a static site generator that's easy to use, template, and theme. If you're already using Node.js in your development workflow, Eleventy may be a more natural fit than Jekyll or Hugo. It provides great results quickly and saves you from complex site design and maintenance. To learn more about using Eleventy, read through its [documentation][6].
|
|
||||||
|
|
||||||
* * *
|
|
||||||
|
|
||||||
_This is based on [Building a technical documentation static site for open source projects][7], which first appeared on Nwokocha Wisdom Maduabuchi's Medium site, and is republished with permission._
|
|
||||||
|
|
||||||
See how Jekyll, an open source generator of static HTML files, makes running a blog as easy as...
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
via: https://opensource.com/article/21/6/static-site-builder
|
|
||||||
|
|
||||||
作者:[Nwokocha Wisdom][a]
|
|
||||||
选题:[lujun9972][b]
|
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
||||||
|
|
||||||
[a]: https://opensource.com/users/wise4rmgod
|
|
||||||
[b]: https://github.com/lujun9972
|
|
||||||
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/computer_desk_home_laptop_browser.png?itok=Y3UVpY0l (Digital images of a computer desktop)
|
|
||||||
[2]: https://www.11ty.dev/
|
|
||||||
[3]: https://opensource.com/article/17/4/getting-started-jekyll
|
|
||||||
[4]: https://opensource.com/article/18/3/start-blog-30-minutes-hugo
|
|
||||||
[5]: https://nodejs.org/en/
|
|
||||||
[6]: https://www.11ty.dev/docs/getting-started/
|
|
||||||
[7]: https://wise4rmgodadmob.medium.com/building-a-technical-documentation-static-site-for-open-source-projects-7af4e73d77f0
|
|
142
translated/tech/20210615 Build a static website with Eleventy.md
Normal file
142
translated/tech/20210615 Build a static website with Eleventy.md
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
[#]: subject: (Build a static website with Eleventy)
|
||||||
|
[#]: via: (https://opensource.com/article/21/6/static-site-builder)
|
||||||
|
[#]: author: (Nwokocha Wisdom https://opensource.com/users/wise4rmgod)
|
||||||
|
[#]: collector: (lujun9972)
|
||||||
|
[#]: translator: (geekpi)
|
||||||
|
[#]: reviewer: ( )
|
||||||
|
[#]: publisher: ( )
|
||||||
|
[#]: url: ( )
|
||||||
|
|
||||||
|
用 Eleventy 建立一个静态网站
|
||||||
|
======
|
||||||
|
Eleventy 是一个基于 JavaScript 的 Jekyll 和 Hugo 的替代品,用于构建静态网站。
|
||||||
|
![Digital images of a computer desktop][1]
|
||||||
|
|
||||||
|
静态网站生成器是一种基于原始数据和一组模板生成完整的静态 HTML 网站的工具。它自动完成单个 HTML 页面的编码任务,并让这些页面准备好为用户服务。由于 HTML 页面是预先建立的,它们在用户的浏览器中加载得非常快。
|
||||||
|
|
||||||
|
静态网站对文档也很友好,因为静态网站很容易扩展,而且它们是生成、维护和部署项目文档的一种简单方法。由于这些原因,企业经常使用它们来记录应用编程接口 (API)、数据库模式和其他信息。文档是软件开发、设计和其他方面技术的一个重要组成部分。所有的代码库都需要某种形式的文档,选择范围从简单的 README 到完整的文档。
|
||||||
|
|
||||||
|
### Eleventy: 一个静态网站生成器
|
||||||
|
|
||||||
|
[Eleventy][2] (11ty) 是一个简单的静态网站生成器,是 [Jekyll][3] 和 [Hugo][4] 的替代品。它是用 JavaScript 编写的,它将一个模板目录(不同类型)转化为 HTML。它也是开源的,在 MIT 许可下发布。
|
||||||
|
|
||||||
|
Eleventy 可以与 HTML、Markdown、Liquid、Nunjucks、Handlebars、Mustache、EJS、Haml、Pug 和 JavaScript Template Literals 协同工作。
|
||||||
|
|
||||||
|
它的特点包括:
|
||||||
|
|
||||||
|
* 易于设置
|
||||||
|
* 支持多种模板语言(如 Nunjucks、HTML、JavaScript、Markdown、Liquid)
|
||||||
|
* 可定制
|
||||||
|
* 基于 JavaScript,这是许多网络开发者所熟悉的,新用户也容易学习
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### 安装 Eleventy
|
||||||
|
|
||||||
|
Eleventy 需要 Node.js。在 Linux 上,你可以使用你的包管理器安装 Node.js:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ sudo dnf install nodejs`
|
||||||
|
```
|
||||||
|
|
||||||
|
如果你的包管理器没有 Node.js,或者你不在 Linux 上,你可以从 Node.js 网站[安装它][5]。
|
||||||
|
|
||||||
|
Node.js 安装完毕后,就用它来安装 Eleventy:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ npm install -g @11ty/eleventy`
|
||||||
|
```
|
||||||
|
|
||||||
|
这就完成了!
|
||||||
|
|
||||||
|
### 为你的文档建立一个静态网站
|
||||||
|
|
||||||
|
现在你可以开始使用 Eleventy 来建立你的静态文档网站。以下是需要遵循的步骤。
|
||||||
|
|
||||||
|
#### 1\. 创建一个 package.json 文件
|
||||||
|
|
||||||
|
要将 Eleventy 安装到你的项目中,你需要一个 package.json 文件:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ npm init -y`
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 2\. 将 Eleventy 安装到 package.json 中
|
||||||
|
|
||||||
|
安装 Eleventy 并保存到你的项目的 `package.json` 中,通过运行:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ npm install-save-dev @11ty/eleventy`
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 3\. 运行 Eleventy
|
||||||
|
|
||||||
|
使用 `npx` 命令来运行你本地项目的 Eleventy 版本。在你确认安装完成后,尝试运行 Eleventy:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ npx @11ty/eleventy`
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 4\. 创建一些模板
|
||||||
|
|
||||||
|
现在运行两个命令来创建两个新的模板文件(一个 HTML 和一个 Markdown 文件):
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
$ cat << EOF >> index.html
|
||||||
|
<!doctype html><html>
|
||||||
|
<head>
|
||||||
|
<title>Page title</title>
|
||||||
|
</head><body>
|
||||||
|
<p>Hello world</p>
|
||||||
|
</body></html>
|
||||||
|
EOF
|
||||||
|
$ echo '# Page header' > index.md
|
||||||
|
```
|
||||||
|
|
||||||
|
这就把当前目录或子目录中的任何内容模板编译到输出文件夹中(默认为 `_site`)。
|
||||||
|
|
||||||
|
运行 `eleventy --serve` 来启动一个开发网络服务器。
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ npx @11ty/eleventy-serve`
|
||||||
|
```
|
||||||
|
|
||||||
|
在你的网络浏览器中打开 `http://localhost:8080/README/`,看你的 Eleventy 输出。
|
||||||
|
|
||||||
|
然后把 `_site` 中的文件上传到你的网络服务器,发布你的网站给世界看。
|
||||||
|
|
||||||
|
### 尝试 Eleventy
|
||||||
|
|
||||||
|
Eleventy 是一个静态网站生成器,它易于使用,有模板和主题。如果你已经在你的开发流程中使用 Node.js,Eleventy 可能比 Jekyll 或 Hugo 更自然。它能快速提供很好的结果,并使你免于复杂的网站设计和维护。要了解更多关于使用 Eleventy 的信息,请仔细阅读它的[文档][6]。
|
||||||
|
|
||||||
|
* * *
|
||||||
|
|
||||||
|
_本文基于[为开源项目建立技术文档静态网站][7],首次发布在 Nwokocha Wisdom Maduabuchi 的 Medium 上,经授权转载。_
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://opensource.com/article/21/6/static-site-builder
|
||||||
|
|
||||||
|
作者:[Nwokocha Wisdom][a]
|
||||||
|
选题:[lujun9972][b]
|
||||||
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]: https://opensource.com/users/wise4rmgod
|
||||||
|
[b]: https://github.com/lujun9972
|
||||||
|
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/computer_desk_home_laptop_browser.png?itok=Y3UVpY0l (Digital images of a computer desktop)
|
||||||
|
[2]: https://www.11ty.dev/
|
||||||
|
[3]: https://opensource.com/article/17/4/getting-started-jekyll
|
||||||
|
[4]: https://opensource.com/article/18/3/start-blog-30-minutes-hugo
|
||||||
|
[5]: https://nodejs.org/en/
|
||||||
|
[6]: https://www.11ty.dev/docs/getting-started/
|
||||||
|
[7]: https://wise4rmgodadmob.medium.com/building-a-technical-documentation-static-site-for-open-source-projects-7af4e73d77f0
|
Loading…
Reference in New Issue
Block a user