koa2给所有页面渲染全局数据

场景

给我的博客增加显示用户访问量,后台的每个请求访问量都新增1,每个页面的渲染都返回当前访问量计数。

捕捉每次请求

在所有路由之前新增

  app.use(async (ctx, next) => {
    const totalhit = await Extends.addHit(ctx.path);
    ctx.state = Object.assign(ctx.state, { totalhit: totalhit });
    await next();
  })

Extends.addHit写入mongodb新增访问量并且返回当前总访问量

每个请求中返回总访问量

还是在上面的代码中将总访问量totalhit赋值给ctx.state,由于state是一个对象,可能存在其他数据所以要使用Object.assign的方式将总访问量属性拷贝给state对象。

这样,每个渲染的html模板都可以获取totalhit变量。本博客使用的模板引擎是koa-swig。

前端实现

<a href="http://3inns.cn" style="color:red;">
{% if totalhit %}
您是第{{ totalhit }}位访问者
{% else %}
3inns.cn
{% endif %}
</a>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值