Skip to content

上一章,我们通过极简 Web 服务的例子来演示如何查看官方文档。

为什么要把查阅官方文档进行特别说明呢?因为查看文档是一个很重要的能力,就跟查字典一样。

回想一下,我们读小学,初中的时候,老师是不是专门教过如何查阅字典呢?不知道现在还是不是这样,笔者以前读小学,初中,新华字典是每个人书桌必备的。

所以,如果你在学习 Node.js 的过程中,或者学习其他技术,都可以用此方法来对语言,技术等进行学习和了解。

那么本章呢,我们继续前进,当浏览器发起请求的时候,返回一个网页并正确渲染网页中涉及到的 CSS、JS 脚本等资源。

js
import { createServer } from 'node:http';

const server = createServer((req, res) => {
    res.end(`
        <!DOCTYPE html>
        <html>
            <head>
                <meta charset="utf-8" />
                <title>显示HTML文件</title>
            </head>
            <body>
                这是一个HTML文件
            </body>
        </html>
    `);
});

server.listen(3000, '127.0.0.1', () => {
    console.log('服务已启动,监听端口为:3000');
});

先简单直接一点,直接把 HTML 字符串返回 (不要忘记重新启动 Web 服务哦)。

简单返回HTML

然后到浏览器访问,可以看到正确地显示了 HTML 效果。

继续,加点料,把 CSS 写进去。

js
import { createServer } from 'node:http';

const server = createServer((req, res) => {
    res.end(`
        <!DOCTYPE html>
        <html>
            <head>
                <meta charset="utf-8" />
                <title>显示HTML文件</title>
                <style>
                    body{
                        color:red;
                    }
                </style>
            </head>
            <body>
                这是一个HTML文件
            </body>
        </html>
    `);
});

server.listen(3000, '127.0.0.1', () => {
    console.log('服务已启动,监听端口为:3000');
});

很简单的效果,让 body 中的文字变成红色。

字体变色

不出所料,尽在掌控,是不是很简单?来,加点难度。

js
import { createServer } from 'node:http';

const server = createServer((req, res) => {
    res.end(`
        <!DOCTYPE html>
        <html>
            <head>
                <meta charset="utf-8" />
                <title>显示HTML文件</title>
                <link rel="stylesheet" type="text/css" href="./index.css" />
            </head>
            <body>
                这是一个HTML文件
            </body>
        </html>
    `);
});

server.listen(3000, '127.0.0.1', () => {
    console.log('服务已启动,监听端口为:3000');
});

把头部的样式单独放到一个文件中,用 link 标签引用。

此时的项目结构如下:

bash
CoolApi/
├── index.css
├── server.js
└── package.json

文字怎么没变色

怎么回事?文字怎么没变色?还有,index.css 文件怎么返回的是 html 内容呢?

点击看看

不仅如此,浏览器一共发送了 3 个请求,返回的内容也都是一模一样的,有蹊跷。

我们再回过头去看看代码,可以发现,我们每次请求,都返回了同样的内容,都是 html 字符。

那么我们要怎么做,才能让不同的请求返回不同的内容?

很简单,if 判断就完事了。但是,怎么判断?判断什么参数呢?

也很简单,打印就完事了,打印谁呢?打印 req 参数。

js
import { createServer } from 'node:http';

const server = createServer((req, res) => {
    console.log(req); // 注意这里
    res.end(`
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8" />
            <title>显示HTML文件</title>
            <link rel="stylesheet" type="text/css" href="./index.css" />
        </head>
        <body>
            这是一个HTML文件
        </body>
    </html>
   `);
});

server.listen(3000, '127.0.0.1', () => {
    console.log('服务已启动,监听端口为:3000');
});

知道笔者的这个课程为什么叫做 实验指南 了吗?这个就是笔者的学习方式,哪里不懂,打印出来看,不要去猜,要用眼睛去观察,要不断地做实验,用数据说话。

查看请求细节

打印的参数很多,我们抽丝剥茧,找到这个关键的地方,恰好是那 3 个请求内容。现在知道怎么判断,判断谁了吗?没错,就是 url

我们约定以下规则:

  1. 如果 url=/,则返回 HTML 页面。
  2. 如果 url=/index.css,则返回 CSS 样式。
  3. 如果 url=/favicon.ico,则返回网页标题栏的收藏图标。
js
import { createServer } from 'node:http';
import { readFileSync } from 'node:fs';

const server = createServer((req, res) => {
    // 返回HTML网页
    if (req.url === '/') {
        res.end(`
            <!DOCTYPE html>
            <html>
                <head>
                    <meta charset="utf-8" />
                    <title>显示HTML文件</title>
                    <link rel="stylesheet" type="text/css" href="./index.css" />
                </head>
                <body>
                    这是一个HTML文件
                </body>
            </html>
        `);
    }

    // 返回CSS样式
    if (req.url === '/index.css') {
        res.end(`body{color:red;}`);
    }

    // 返回收藏图标
    if (req.url === '/favicon.ico') {
        res.end(readFileSync('./favicon.ico'));
    }
});

server.listen(3000, '127.0.0.1', () => {
    console.log('服务已启动,监听端口为:3000');
});

很简单的判断,不同的路径返回不同的内容。另外,收藏图标用到了文件读取方法,很简单,看下官方文档,搜索下资料就懂了,不多赘述。

样式生效了

可以看到,收藏图标有了,CSS 样式也生效了,3 个请求返回也不一样了。

好像一切都完美了?其实不然,由于浏览器的包容性,一些玄机还暗藏其中,且听下回分解。

何以解忧,唯有代码。不忘初心,方得始终。