[Node.js] Level 5. Express
Express Routes
Let's create an express route that accepts GET requests on'/tweets'
and responds by sending back a static HTML file.
Create a GET route for '/tweets'
and give it the proper callback. The callback function should accept two arguments: the request and the response.
Send back the file tweets.html
, which lives under the project's root path. Remember to use __dirname
to locate tweets.html
.
Finally, have the express app listen on port 8080.
var express = require('express');
var app = express(); app.get('/tweets', function(request, response){
response.sendFile( __dirname + '/tweets.html');
}).listen(8080);
Route Params 250 PTS
Let's create a route that accepts dynamic arguments in the URL path and and responds with the quote from the proper author.
Start by creating a GET route for '/quotes'
that takes a name
parameter as part of the URL path.
Now, use the name
parameter from the URL to retrieve a quote from the quotes object and write it out to the response. Note: No piping here, just write the quote string to the response like you did in previous levels (and then close the response).
var express = require('express');
var app = express(); var quotes = {
'einstein': 'Life is like riding a bicycle. To keep your balance you must keep moving',
'berners-lee': 'The Web does not just connect machines, it connects people',
'crockford': 'The good thing about reinventing the wheel is that you can get a round one',
'hofstadter': 'Which statement seems more true: (1) I have a brain. (2) I am a brain.'
}; app.get('/quotes/:name', function(req, response){
response.end(quotes[req.params.name]);
}); app.listen(8080);
Rendering
Instead of just writing out the quote to the response, let's try using an EJS template to render the response.
First, render the quote.ejs
template to the response.
Next, make the name
and the quote
data available to the template.
res.locals = {name: req.params.name, quote: quote};
Inside quote.ejs
, add the code needed to render the data you passed to the template.
<h2>Quote by <%= name %></h2> <blockquote>
<%= quote %>
</blockquote>
URL Building
Let's create a page which calls the Twitter search API and displays the last few results for Code School. The first step is to construct the proper URL, which is all you need to do in this challenge.
Complete the URL options which will be sent into the the url
module's format method. The URL you'll want to construct is the following: http://search.twitter.com/search.json?q=codeschool
Add the protocol
attribute to options
.
Add the host
attribute to options
.
Add the pathname
attribute to options
.
Add an attribute which takes an object of query parameters, in this case we only need q
to search Twitter.
var url = require('url'); options = {
// add URL options here
protocol: 'http:',
host : 'search.twitter.com',
pathname : '/search.json',
query: {q:'codeschool'}
}; var searchURL = url.format(options);
console.log(searchURL);
Doing the Request
Next, we'll use the request module to make a simple web request and log the response to the console. You can use this example in the README.
To start, require the request
module and assign the return function to a variable.
Next, issue a request to searchURL
. Remember, the callback function for the request function takes three arguments: error
, response
and body
.
Finally, log the response body to the console using console.log()
.
var url = require('url'); var options = {
protocol: "http:",
host: "search.twitter.com",
pathname: '/search.json',
query: { q: "codeschool"}
}; var searchURL = url.format(options);
var request = require('request');
request(searchURL, function(error, response , body){
console.log(body);
});
Express Server
Now, let's create an Express server which queries out for the search term and then returns the JSON.
Require the express
module.
Create the Express server and name it app
.
Create a route for GET requests to /
(root path). Remember, the callback function takes two arguments: a request req
and a response res
.
In our new route, issue a request to searchURL
and pipe the results into the response.
Finally, tell app
to listen on port 8080
.
var url = require('url');
var request = require('request');
var express = require('express'); var options = {
protocol: "http:",
host: "search.twitter.com",
pathname: '/search.json',
query: {
q: "codeschool"
}
}; var searchURL = url.format(options); var app = express(); // Create server here
app.get('/', function(req, res){
request(searchURL).pipe(res);
}).listen(8080);
[Node.js] Level 5. Express的更多相关文章
- node.js 下依赖Express 实现post 4种方式提交参数
上面这个图好有意思啊,哈哈, v8威武啊.... 在2014年的最后一天和大家分享关于node.js 如何提交4种格式的post数据. 上上一篇说到了关于http协议里定义的4种常见数据的post方法 ...
- Node.js的框架-express
Node.js的框架 express 是第三方的 express const express=require('express'); const app=express(); const PORT=3 ...
- Node.js 实战 & 最佳 Express 项目架构
Node.js 实战 & 最佳 Express 项目架构 Express Koa refs https://github.com/xgqfrms/learn-node.js-by-practi ...
- node.js入门及express.js框架
node.js介绍 javascript原本只是用来处理前端,Node使得javascript编写服务端程序成为可能.于是前端开发者也可以借此轻松进入后端开发领域.Node是基于Google的V8引擎 ...
- node.js 基础学习 express安装使用
安装好nodeJs,我们需要使用命令行中安装express. 我这里默认将Node.js安装在C:\Program Files\nodCejs\盘中. 在保持联网的状态下,依次输入如下命令. npm ...
- 建立一个node.js服务器(使用express搭建第一个Web环境)
一.官网下载node.js 下载地址:https://nodejs.org/en/download/ 根据向导,下一步安装就可以了! 二.使用express搭建Web环境 express是一个开源的n ...
- Node.js 入门:Express + Mongoose 基础使用
前言 Express 是基于 Node.js 平台的 web 应用开发框架,在学习了 Node.js 的基础知识后,可以使用 Express 框架来搭建一个 web 应用,实现对数据库的增删查改. 数 ...
- Node.js原生及Express方法实现注册登录原理
由于本文只是实现其原理,所以没有使用数据库,只是在js里面模拟数据库,当然是种中还是需要用数据库的. 1.node.js原生方法 ①html页面,非常简单,没有一丝美化~我们叫它user.html & ...
- node.js上除了Express还有哪些好用的web开发框架
老司机都有体会, 开发本身没有多难, 最纠结其实是最初的技术和框架选型, 本没有绝对的好坏之分, 可一旦选择了不适合于自己业务场景的框架, 将来木已成舟后开发和维护成本都很高, 等发现不合适的时候更换 ...
随机推荐
- Django项目中模板标签及模板的继承与引用【网站中快速布置广告】
Django项目中模板标签及模板的继承与引用 常见模板标签 {% static %} {% for x in range(x) %}{% endfor %} 循环的序号{% forloop %} 循环 ...
- go chapter 11 初始化 map 数组
// 初始化 map m1 = make(map[string]string) // 初始化 数组 var array3 = []int{9, 10, 11, 12} var a [4]int a[0 ...
- Xcode代码提示里的字母含义
P -- 协议 M -- 成员方法 C -- 类 K -- 枚举 .常量 V -- 成员变量 T -- typedef类型 G -- 全局变量 f -- 函数 # -- #define指令
- redux 初步理解
派发一个 action 给 reducer, reducer 生成了一个新的 state; redux 通过 Store 来保存数据, store.getState 获得数据, 而要更新 state, ...
- 【BZOJ 1272】 1272: [BeiJingWc2008]Gate Of Babylon (容斥原理+卢卡斯定理)
1272: [BeiJingWc2008]Gate Of Babylon Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 254 Solved: 12 ...
- BZOJ1064 NOI2008假面舞会
挺神的这题,发现只有环和链两种情况 搜索时我们只考虑环的,因为链可以看成找不到分类的环. 当成链时大小是的最大值是各链长的和,最小值是3 当成环时最大值是各环长的gcd,最小值是大于3的最小的ans的 ...
- POJ2185 Milking Grid KMP两次(二维KMP)较难
http://poj.org/problem?id=2185 大概算是我学KMP简单题以来最废脑子的KMP题目了 , 当然细节并不是那么多 , 还是码起来很舒服的 , 题目中描写的平铺是那种瓷砖一 ...
- bzoj 2251
第一道后缀数组 后缀数组要维护三个数组:sa(suffix array), rk(rank)和ht(height). 含义分别是: sa[i]:将后缀按照字典序排序后,第i大的后缀的起始位置. rk[ ...
- DML、DDL、DCL是什么?
一.DML DML(data manipulation language)数据操纵语言: 我们经常会用到的 INSERT.DELETE.UPDATE.SELECT语句. 主要用来对数据库的数据进行一些 ...
- Codeforces Beta Round #8 A. Train and Peter KMP
A. Train and Peter 题目连接: http://www.codeforces.com/contest/8/problem/A Description Peter likes to tr ...