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传入然后显示产品详情页了;

相关推荐
火乐暖阳851052 小时前
vue3+node.js:一个基础入门的全栈CURD模块
node.js
zhensherlock3 小时前
Protocol Launcher 系列:Working Copy 提交与同步全攻略
javascript·git·typescript·node.js·自动化·github·js
无巧不成书021819 小时前
2026最新Next-AI-Draw-io全攻略:AI驱动专业图表生成,Docker/Node.js本地部署零踩坑指南
人工智能·docker·node.js·next-ai-draw-io
悟空瞎说1 天前
我踩过的4个Node.js微服务经典Bug,用一个库彻底解决(2000字详解+可直接复用代码)
后端·node.js
捉鸭子1 天前
某红书X-s X-s-common VMP逆向(算法还原)
python·web安全·网络安全·node.js·网络爬虫
freewlt1 天前
Node.js 性能分析实战指南:从入门到精通
node.js
火乐暖阳851051 天前
Vue3+Node.js
vue.js·node.js·pnpm·koa2·myslq2
被巨款砸中1 天前
从零到一:构建高效 Node.js 后端 API (Koa + Prisma 实战)
前端·javascript·vue.js·node.js·web
网络点点滴1 天前
Node.js-填充模板
node.js