使用zig语言制作简单博客网站(七)右边栏分类点击和文章搜索

news/2025/1/19 8:10:23/文章来源:https://www.cnblogs.com/tingyublog/p/18392765

分类点击事件处理

后端代码

  • sqlite数据库article表新增cate_name字段
CREATE TABLE article (id          INTEGER        PRIMARY KEY AUTOINCREMENT,title       VARCHAR (1024) NOT NULL,description VARCHAR (1024),content     TEXT           NOT NULL,istop       INTEGER (2)    NOT NULL DEFAULT (0),cate_name   VARCHAR (20),created_at  DATETIME,updated_at  DATETIME
);
  • 更新model/article.zig
pub const Article = struct {id: u32,title: []const u8,description: []const u8,content: []const u8,istop: u32,cate_name: []const u8,created_at: []const u8,updated_at: []const u8,
};
  • 注册路由
    // 某分类下博客router.get("/api/articles", &articleController.getArticlesByCateName);
  • article_controller.zig代码
/// 获取分类下的文章列表
pub fn getArticlesByCateName(req: *httpz.Request, res: *httpz.Response) !void {const query = try req.query();if (query.get("cate")) |cate_name| {const articles = try article_server.getArticlesByCateName(cate_name);res.status = 200;try res.json(.{ .code = 200, .msg = "ok", .data = articles }, .{});} else {res.status = 400;try res.json(.{ .code = 400, .msg = "错误的请求" }, .{});return;}
}
  • article_server.zig代码
/// 获取分类下的文章列表
pub fn getArticlesByCateName(cate_name: []const u8) ![]ArticleModel.Article {var db = try database.OpenDb();defer db.deinit();const query =\\SELECT id, title, description, content, istop, cate_name, created_at, updated_at FROM article WHERE cate_name = ? ORDER BY created_at DESC;var stmt = try db.prepare(query);defer stmt.deinit();var gpa = std.heap.GeneralPurposeAllocator(.{}){};const allocator = gpa.allocator();const rows = try stmt.all(ArticleModel.Article,allocator,.{},.{ .cate_name = cate_name },);return rows;
}

前端代码

分类点击前端代码
<!DOCTYPE html>
<html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="./css/index.css"><link rel="stylesheet" href="./css/prism.css"><title>blog</title><style>[v-cloak] {display: none;}</style>
</head><body><div id="app"><!-- 移动端菜单 --><span class="mnavbtn" onclick="openMnav()"><svg width="25" height="25" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><pathd="M0 96C0 78.3 14.3 64 32 64H416c17.7 0 32 14.3 32 32s-14.3 32-32 32H32C14.3 128 0 113.7 0 96zM0 256c0-17.7 14.3-32 32-32H416c17.7 0 32 14.3 32 32s-14.3 32-32 32H32c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32H32c-17.7 0-32-14.3-32-32s14.3-32 32-32H416c17.7 0 32 14.3 32 32z" /></svg></span><div id="mySideMnav" class="sidemnav"><a href="javascript:;" class="closemnavbtn" onclick="closeMnav()">&times;</a><a href="#">首页</a><a href="#">归档</a><a href="#">关于</a><a href="#">资源</a></div><div class="container"><!-- 左侧导航 --><div class="nav"><div class="logo"><img src="./img/logo.jpg"><h2>※听雨※</h2></div><div style="margin: 30px auto;text-align: center;"><span style="cursor: pointer;margin: 0 5px;"><svg width="25" height="25" xmlns="http://www.w3.org/2000/svg" width="16" height="16"fill="currentColor" class="bi bi-envelope-fill" viewBox="0 0 16 16"><pathd="M.05 3.555A2 2 0 0 1 2 2h12a2 2 0 0 1 1.95 1.555L8 8.414.05 3.555ZM0 4.697v7.104l5.803-3.558L0 4.697ZM6.761 8.83l-6.57 4.027A2 2 0 0 0 2 14h12a2 2 0 0 0 1.808-1.144l-6.57-4.027L8 9.586l-1.239-.757Zm3.436-.586L16 11.801V4.697l-5.803 3.546Z" /></svg></span><span style="cursor: pointer;margin: 0 5px;"><svg width="25" height="25" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><pathd="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z" /></svg></span></div><div class="navlink"><ul class="navlist"><li><a href="/front/index.html">首页</a></li><li><a href="javascript:;">归档</a></li><li><a href="javascript:;">关于</a></li><li><a href="javascript:;">资源</a></li><li><a href="/light-year-admin/index.html">后台</a></li></ul></div></div><!-- 中间内容 --><div class="main"><div style="margin-top: 35px;"></div><div v-cloak v-if="articleListIsShow"><template v-for="(article, index) in articleList" :key="index"><div class="article-card" :class="{sticky: article.istop}"><div class="article-card-container"><h4 class="article-card-title" @click="getArticleDetail(article.id)"><i class="sticky-icon" v-cloak v-if="article.istop">⚘</i>{{article.title}}</h4><div class="article-card-des">{{article.description}}</div><div class="article-card-footer"><span class="article-card-footer-author">作者:听雨</span><span class="article-card-footer-date">发布时间:{{article.created_at}}</span><span class="article-card-footer-cate">分类:{{article.cate_name}}</span></div></div></div></template></div><!-- 文章详情 --><div class="article-container" v-cloak v-if="articleDetailIsShow"><div style="float: right;color: red;cursor: pointer;" @click="returnHomePage()">&lt;&lt;返回</div><div class="article-main"><article class="article-view"><h1 class="article-title">{{article.title}}</h1><div class="article-meta"><span>作者: 听雨</span><span>分类:{{article.cate_name}}</span><span>发布时间: {{article.created_at}}</span></div><div class="article-desc">{{article.description}}</div><div class="article-content" v-html="article.content"></div></article></div></div></div><!-- 右侧面板 --><div class="rside" v-cloak v-if="rsideIsShow"><!-- 搜索框 --><div class="search-box"><input class="search-txt" type="text" placeholder="输入内容搜索"><input class="search-bnt" type="submit" value="搜索"></div><!-- 文章分类 --><div class="rside-card"><div class="rside-card-container"><h4 class="rside-card-title">分类</h4><div class="rside-card-body"><li v-for="(cate, index) in cateList" :key="index" @click="cateOnClick(cate.name)">{{cate.name}}</li></div></div></div><!-- 文章标签 --><!-- <div class="rside-card"><div class="rside-card-container"><h4 class="rside-card-title">标签</h4><div class="rside-card-body"><li>winform</li><li>spring</li><li>Django</li></div></div></div> --></div></div></div><script src="./js/index.js"></script><script src="./js/zepto.min.js"></script><script src="./js/prism.js"></script><script type="module">import { createApp, ref, onMounted, } from "./js/vue.esm-browser.prod.js";createApp({setup() {const articleList = ref({});    // 首页文章列表const cateList = ref({});    // 首页分类列表const article = ref({});    // 文章详情对象const articleListIsShow = ref(true); // 是否显示文章列表const articleDetailIsShow = ref(false); // 是否显示文章详情const rsideIsShow = ref(true);  // 是否显示右侧面板// 获取首页文章列表const getArticleList = () => {$.ajax({url: 'http://localhost:5588/api/home/articles',type: 'GET',dataType: 'json',success: function (res) {if (res.code == 200) {let data = res.data.sort((a, b) => b.istop - a.istop);articleList.value = data;return;}layer.msg(res.msg);},error: function (err) {console.log(err.responseText);layer.msg(res.msg);}});};// 获取首页分类列表const getCateList = () => {$.ajax({url: 'http://localhost:5588/api/home/cates',type: 'GET',dataType: 'json',success: function (res) {if (res.code == 200) {cateList.value = res.data;}},error: function (err) {console.log(err.responseText);}});};// 获取文章详情const getArticleDetail = (id) => {$.ajax({url: `http://localhost:5588/api/article/${id}`,type: 'GET',dataType: 'json',success: function (res) {if (res.code == 200) {article.value = res.data;rsideIsShow.value = false;articleListIsShow.value = false;articleDetailIsShow.value = true;}},error: function (err) {console.log(err.responseText);}});};// 从文章详情页返回首页const returnHomePage = () => {articleDetailIsShow.value = false;articleListIsShow.value = true;rsideIsShow.value = true;};// 分类点击事件const cateOnClick = (cateName) => {$.ajax({url: "http://localhost:5588/api/articles",type: 'GET',dataType: 'json',data: {cate: cateName},success: function (res) {if (res.code == 200) {articleList.value = res.data;}},error: function (err) {console.log(err.responseText);}});};// 页面加载时执行onMounted(() => {getArticleList();getCateList();});return {articleList,cateList,article,articleListIsShow,articleDetailIsShow,rsideIsShow,getArticleDetail,returnHomePage,cateOnClick,}}}).mount('#app');</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/791069.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ECharts实现雷达图详解

ECharts 是一款由百度开源的数据可视化工具,它提供了丰富的图表类型,如折线图、柱状图、饼图、散点图、雷达图、地图、K线图、热力图、仪表盘等,以及丰富的交互功能。ECharts 组件的核心功能实现原理主要包括以下几个方面:数据驱动: ECharts 采用数据驱动的设计理念,图表…

HTB-Runner靶机笔记

HTB-Runner靶机笔记 概述 Runner是HTB上一个中等难度的Linux靶机,它包含以下teamcity漏洞(CVE-2023-42793)该漏洞允许用户绕过身份验证并提取API令牌。以及docker容器逃逸CVE-2024-21626,进行提权操作 Runner靶机地址:https://app.hackthebox.com/machines/Runner 一、nmap …

【新品8折】正点原子ZYNQ7035/7045/7100开发板发布、ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2!

【新品发布】正点原子FPGA新品ZYNQ7035/7045/7100开发板,ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2! 正点原子Z100 ZYNQ开发板,搭载Xilinx Zynq7000系列芯片,核心板支持Xilinx Zynq-7035、Zynq-7045和Zynq-7100三种型号。开发板由核心板+底板组成,外设资源丰富,板载2路千兆…

达梦存储过程性能问题定位

在达梦数据库中可以通过V$DMSQL_EXEC_TIME和debug方式来定位存储过程存在的性能问题,但V$DMSQL_EXEC_TIME往往定位比较粗糙,没法定位到存储过程中sql的执行时间,而debug可以点位具体某段sql,但如果存储过程里面有大量游标,参数变量值很多的情况下,debug调试也花费大量时间…

redis-数据结构数据类型

redis常见数据类型 作者:x x x Redis 共有 5 种基本数据类型:String(字符串)、List(列表)、Set(集合)、Hash(散列)、Zset(有序集合)。数据类型 底层数据结构 应用场景String SDS 它可以存储任何数据 - 字符串、整数、浮点值、JPEG 图像、序列化的 Ruby 对象或您希望…

SHxxx传感器集线器,最多支持100组频率+温度传感器接入,满足您的多通道需求

SHxxx传感器集线器,最多支持100组频率+温度传感器接入,满足您的多通道需求SHxxx是一个传感器集线器,能够将多路传感器轮转切换到单一接口(最多200路)。它解决了测试现场传感器数量较多时传感器编号混乱的问题。该传感器集线器适用于2/3/4线制的所有传感器,例如振弦、NTC热…

Idea如何提交本地项目到Gitee或Gitlab等远程仓库

Idea、提交Git代码1、确定远程仓库地址 2、确认自己的Git账号密码(提交代码时需要登录)如果是自己的Gitee码云则是自己登录码云的账号密码; 如果是公司的GitLab则以公司分给自己的Git账号密码为准。3、确定自己本地安装了Git,然后用Idea创建或者开发好代码4、初始化本地项目…

孩子特有的纯真

写在前面1447 字 | 感触 | 见闻 | 孩子 | 童真 | 天性正文晚上。跳舞。老师有很多学生,几乎都念小学,大的不过五年级。小孩子。今晚只来了一个。其他的孩子据说都在写作业。这几天老师都打算回归街舞本源,去街上跳舞,于是让我们大包小包拿东西。音箱、地胶、小型探照灯,水…

线上applicationExecutor启动bean未加载到问题

项目启动报错applicationExecutor问题SpringBoot applicationExecutor启动bean未加载到 1. 环境 springboot3.x + flowable 2. 问题原因 报错日志:明显的使用线程池的时候Bean加载问题, 发现报错日志后再代码中搜索是否存在这个bean, 最终发现并没有, 这个bean是spring官方创建…

Camera Link转光纤卡设计资料:153-基于Sprtan6的Full(Base) Camera Link 信号源

基于Sprtan6的Full(Base) Camera Link 信号源 一、板卡概述板卡采用单FPGA的结构,FPGA采用XILINX的SPARTAN6系列的XC6SLX45T-1FF484I,用来实现Full 模式下的一路Camera Link转光纤功能输出。二、主要功能和性能板卡功能参数内容一路Full 模式下的Camera Link转光纤功能XC6SLX…

goland idea中debug程序报错-debugger could not patch runtime.mallogc

idea中debug Go程序报错error layer=debugger could not patch runtime.mallogc 一、问题场景在idea中配置了Go编程环境,可以运行Go程序,但是无法debug,报错error layer=debugger could not patch runtime.mallogc: no type entry found, use ‘types’ for a list of valid…

一个练习项目,好玩的bbs-nodejs-fastify

代码:const fastify = require("fastify")(); const md5 = require(md5); const querystring = require(querystring);//npm install fastifyvar secretKey = saacac3423@21212; var pagesize = 20;var mysql = require(mysql); var connection = mysql.create…