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

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

时间:2024-09-02 15:52:39浏览次数:12  
标签:const cate res 博客 zig 点击 value article name

分类点击事件处理

后端代码

  • 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">
                <path
                    d="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">
                            <path
                                d="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">
                            <path
                                d="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>

标签:const,cate,res,博客,zig,点击,value,article,name
From: https://www.cnblogs.com/tingyublog/p/18392765

相关文章

  • 点击后隐藏图片,再次点击显示是否有方法实现?
    你可以使用JavaScript来实现这个功能。以下是一个简单的示例:<!DOCTYPEhtml><html><body><imgid="myImage"src="image.jpg"onclick="toggleImage()"><script>functiontoggleImage(){varimage=documen......
  • 使用selenium想要点击并在类中定义URL
    要使用Selenium点击并在类中定义URL,你可以按照以下步骤进行操作:导入所需的库:fromseleniumimportwebdriver创建WebDriver对象:driver=webdriver.Chrome()#请根据你的浏览器类型选择相应的驱动程序导航到目标页面:driver.get('https://example.com')#将'https://examp......
  • 博客园20年纪念T恤上架:艰难的时光,燃烧的希望
    2024年9月开始了,救园的最后一个月到了,园子的20年纪念T恤终于赶在天凉好个秋之前上架了。用这件设计简约清新给人希望的T恤,纪念过去二十年充满艰难而满怀希望的时光。园子的二十年,是困难重重的二十年,是走了很多弯路摔了很多跟头的二十年,但也是心中一直燃烧着希望的二十年——服......
  • 通过 Docker 部署 WordPress 搭建博客保姆级教程
    前言(废话)因为最近想搭建一个属于自己的博客,这样就能像筑巢一样随意装饰自己的家,没有那么多的平台约束。虽然搭建个人博客的框架有很多,比如HEXO,HUGO,VuePress等,但在思前想后,最终还是选择了WordPress。我在部署过程中遇到了一系列的问题:需要什么服务,Mysql、PHP、Nginx?如何突破WordP......
  • C#中数据到底存在堆上还是栈上_c# 自建类在栈里还是在堆里-CSDN博客
    C#中数据到底存在堆上还是栈上_c#自建类在栈里还是在堆里-CSDN博客C#的栈与堆首先复习一下值类型与引用类型1.值类型与引用类型值类型:基本数据类型([int,long,float,char,bool]:System.ValueType,enum,struct)引用类型:类(所有class),string,接口,数组2.栈与堆局部变量,参数,调......
  • 博客园-awescnb插件-geek皮肤优化-目录优化
    ......
  • 博客园-awescnb插件-geek皮肤优化-目录优化
    ......
  • 搭建博客
    Hexo+Git安装Hexohexo文档1.先行条件安装以下应用程序Node.jsGit检验是否安装成功win+r输入cmd进入终端出现版本号即安装成功2.镜像安装Hexo进入npm镜像站在终端输入npminstall-gcnpm--registry=https://registry.npmmirror.comcnpminstall-ghexo-cli效......
  • Hexo + redefine主题配置个人博客
    前置准备安装nodejs安装git安装Hexo创建Github仓库。nodejs:https://nodejs.org/zh-cngit:注:git安装时一直继续就好,但是有path的地方一定要勾选。https://git-scm.com/download/win检查一下是否安装成功,在终端中输入:node-vnpm-vgit--versionHexo:......
  • 高德地图,只有部分marker显示InfoWindow并可点击
    高德地图,只有部分marker显示InfoWindow并可点击   原因:加了MarkerCluster之后,出现不稳定现象“有部分marker显示InfoWindow并可点击”。      //将所有的标记点添加到markercluster//markercluster    // markerLayer.setMarkers(marker......