Node.js从URL中解析变量

Node.js从URL中解析变量

1.URL解析方法

在此之前,我们需要知道url模块的一个内置方法,parse,这个方法是用来将一个URL字符串解析成一个对象,方便我们来提取其中的参数

vue 复制代码
const server = http.createServer((request,response) => {
        console.log(request.url)
        console.log(url.parse(request.url,true));
        const pathName = request.url;
        const chatset = {'Content-type':'text/html;charset=utf-8'}

这里query的输出是node.js故意设计的,并不影响我们访问属性,出现Object: null prototype是因为parse方法会把id解析成一个无原型的对象,没有原型的对象就是没有proto等原型链,不会污染全局对象原型

2.获取属性

  • 这个对象中,我们需要知道路径和参数,组合在一起就能找到我们想要的产品详情了
vue 复制代码
        const {query,pathname} = url.parse(request.url,true);
  • 之后我们获取ID,替换一下模板就可以了
js 复制代码
       //产品页
        } else if(pathName === '/product'){
            response.writeHead(200,{'content-type':'text/html'});
            const productId = dataObj[query.id];
            const output = replaceTemplate(tempProduct,product)
            response.end(output);
  • 但是这个点击返回是没有用的,我们修改一下模板
js 复制代码
<body>
    <div class="container">
        <h1>🌽 节点农场 🥦</h1>
        <figure class="product">
            <div class="product__organic {%NOT_ORGANIC%}">
                <h5>有机</h5>
            </div>
            <a href="/overview" class="product__back">
                <span class="emoji-left">👈</span>返回
            </a>
            <div class="product__hero">
                <span class="product__emoji product__emoji--1">{%IMAGE%}</span>
                <span class="product__emoji product__emoji--2">{%IMAGE%}</span>
                <span class="product__emoji product__emoji--3">{%IMAGE%}</span>
                <span class="product__emoji product__emoji--4">{%IMAGE%}</span>
                <span class="product__emoji product__emoji--5">{%IMAGE%}</span>

这样就实现了通过解析URL将id传入然后显示产品详情页了;

相关推荐
凌云拓界2 小时前
状态机与思考循环 ——CogitoAgent开发实战(一)
javascript·人工智能·架构·node.js·设计规范
winfredzhang4 小时前
用 Node.js + SQLite + 原生前端写一个本地情绪急救 Web App:情绪降落伞 Mood Parachute
前端·sqlite·node.js·express·情绪管理
不好听6135 小时前
Bun vs Node.js:谁才是 TypeScript 的"亲爹"?
typescript·node.js·bun
矩阵科学5 小时前
Langchain.js 实战四:工具的使用
langchain·node.js
前端双越老师6 小时前
2026 年从 0 开发 AI Agent 需要的 10 个技能
node.js·agent·ai编程
夜雪闻竹7 小时前
版本管理:npm 发布 + Electron 打包 + CI/CD
ci/cd·npm·node.js·代码规范·chatcrystal
winfredzhang18 小时前
Node.js + SQLite 实战:本地 Markdown 阅读书架源码深度解析
sqlite·node.js·safari·分页·多媒体·md文档
码云之上19 小时前
聊聊如何设计一个高效、稳定的 Node.js 接入层
前端·后端·node.js
To_OC1 天前
折腾两天 HTTP 接口调用,终于把 fetch 和前后端分离从书本概念落地到实操了
javascript·node.js·全栈
zhangfeng11331 天前
workbuddy ,node.js 每次会在 项目目录上安装 node_modules,能不能一次安装多次使用,为什么 npm 不把包装在全局
前端·npm·node.js