codecamp

Harp 快速入门

本篇内容将会指导您安装 Harp。您将在development模式下创建并维护一个简单的项目,开发模式下预处理会自动进行。而在production模式下,会缓存好预处理后的数据以获得更好的性能。

安装 Harp Web 服务器

首先,安装Node.js 虽然 Harp 使用了 Node.js,但即便不了解 Node.js, 或者没有接触过 JavaScript ,也是可以上手 Harp 的。在 Node.js 安装完成后,就可以使用 Node.js 的包管理器 npm 来安装 Harp 了。这是个基于命令行的工具。

在 OS X 和 Linux 上    

使用终端应用程序访问命令提示符。在 OS X 上,它位于应用程序 → 实用工具 → 终端中。在 Ubuntu 上,在应用程序 → 终端中找到它。 然后,运行以下命令:

sudo npm install -g harp

在 Windows 上

如果您使用的是 Windows,NodeJS 将附带 Node.js 命令提示符应用程序。现在,要通过 npm 安装 Harp,请输入:

npm install -g harp

创建应用程序

Harp 可以非常容易的提供服务,简单到像一个 index.html 一样。因为 Harp 有一个内嵌的预处理器,所以你可以很方便的用模板语言来创建 HTML。比如,用下面的命令行来创建一个 index.jade 文件:

mkdir hello-world
cd hello-world
echo h1 Hello World >> index.jade

以上命令将会创建一个 hello-world 目录用于 Harp 应用。然后,在目录里面,一个 index.jade 被创建出来,然后被处理成 <h1>Hello world</h1>

启动网络服务器

在默认端口上启动 Harp Web 服务器9000

harp server --port 9000

访问localhost:9000 现在将显示以下内容:

在浏览器中弹奏“Hello world”

编译项目

你可以把 Harp 编译后当作一个 web server 来使用。然而 Harp 是为了造出优秀的静态站点而生的。

harp compile

将 Harp 投入生产环境

为了将 Harp 投入生产,你只需要做如下这几点:在生产环境,Harp 将缓存经过预处理的输出以获得尽可能快的性能。在当前这个 case 里面,缓存 index.jade 的预处理结果。别忘了在生产环境里使用 production 标志位 (flag)。

NODE_ENV=production sudo harp server --port 80

你无需在生产环境中手工跑 Harp 来上线新版本。事实上,最简单的办法是使用 Harp Platform,你可以使用 Dropbox 来创建 Harp App,不仅如此,还能多人协作。

你还可以在 Heroku, 上面运行生产环境的 Harp,将 Harp 部署到 GitHub Pages, 针对 Apache Cordova/PhoneGap 编译 Harp 应用。

接下来要做的事

上面只是一次尝试。举个例子,默认 Harp 应用还包括一个 .less 文件,被当成 .css 文件来处理。通过修改 LESS 文件就能调整 CSS,不需要额外配置就可以从默认 App 开始做整个项目。阅读有关初始化默认 Harp 应用程序的更多信息。


Harp 概述
Harp 安装
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }