【项目日记(四)】搜索引擎-Web模块

❣博主主页: 33的博客❣
▶️文章专栏分类:项目日记◀️
🚚我的代码仓库: 33的代码仓库🚚
🫵🫵🫵关注我带你了解更多项目内容

在这里插入图片描述

目录

  • 1.前言
  • 2.前端模块
    • 2.1页面设计
    • 2.2后端交互
  • 3.部署到云服务器
  • 4.总结

1.前言

在前面的文章中我们以及完成了后端的基本模块,那么,接下来,我们对前端模块进行设计。

2.前端模块

2.1页面设计

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Java 文档搜索</title>
</head>
<body><!-- 通过 .container 来表示整个页面元素的容器 --><div class="container"><!-- 1. 搜索框 + 搜索按钮 --><div class="header"><input type="text"><button id="search-btn">搜索</button></div><!-- 2. 显示搜索结果 --><div class="result"><!-- 包含了很多条记录 --><!-- 每个 .item 就表示一条记录 --><!-- 接下来要通过访问服务器的方式获取到搜索结果, 并且由 JS 动态生成页面元素 -->        </div></div>
<style>/* 这部分代码来写样式 *//* 先去掉浏览器的默认样式 */* {margin: 0;padding: 0;box-sizing: border-box;}/* 给整体的页面指定一个高度(和浏览器窗口一样高) */html, body {height: 100%;/* 设置背景图 */background-image: url(image/Pic.jpg);/* 设置背景图不平铺 */background-repeat: no-repeat;/* 设置背景图的位置 */background-position: center center;/* 设置背景图的大小 */background-size: cover;}/* 针对 .container 也设置样式, 实现版心效果 */.container {/* 此处的宽度也可以设置成百分数的形式, 当前就使用一个固定宽度 */width: 1200px;height: 100%;/* 设置水平居中 */margin: 0 auto;/* 设置背景色, 让版心和背景图能够区分开 */background-color: rgba(255, 255, 255, 0.6);/* 设置圆角矩形 */border-radius: 10px;/* 设置内边距, 避免文字内容紧贴着边界 */padding: 20px;/* 加上这个属性, 超出元素的部分就会自动生成一个滚动条. */overflow: auto;}.header {width: 100%;height: 50px;display: flex;justify-content: space-between;align-items: center;}.header>input {width: 1050px;height: 50px;font-size: 22px;line-height: 50px;padding-left: 10px;border-radius: 10px;}.header>button {width: 100px;height: 50px;background-color: rgb(42,107,205);color: #fff;font-size: 22px;line-height: 50px;border-radius: 10px;border: none;}.header>button:active {background: gray;}.result .count {color: gray;margin-top: 10px;}.item {width: 100%;margin-top: 20px;}.item a {display: block;height: 40px;font-size: 22px;line-height: 40px;font-weight: 700;color: rgb(42,107,205);}.item .desc {font-size: 18px;}.item .url {font-size: 18px;color: rgb(0, 128, 0);}.item .desc i {color: red;/* 去掉斜体 */font-style: normal;}</style>

2.2后端交互

<script src="js/jquery.js"></script><script>// 放置用户自己写的 js 代码let button = document.querySelector("#search-btn");button.onclick = function() {// 先获取到输入框的内容let input = document.querySelector(".header input");let query = input.value;console.log("query: " + query);// 然后构造一个 ajax 请求发给服务器$.ajax({type: "GET",url: "searcher?query=" + query,success: function(data, status) {// success 这个函数会在请求成功后调用. // data 参数就表示拿到的结果数据// status 参数就表示 HTTP 状态码// 根据收到的数据结果, 构造出页面内容. // console.log(data);buildResult(data);}})}function buildResult(data) {// 通过这个函数, 来把响应数据给构造成页面内容. // 要做的工作就是, 遍历 data 中的每个元素, // 针对每个元素都创建一个 div.item, 然后把标题, url, 描述都构造好// 再把这个 div.item 给加入到 div.result 中// 这些操作都是基于 DOM API 来展开~// 获取到 .result 这个标签let result = document.querySelector('.result');// 清空上次的结果. result.innerHTML = '';// 先构造一个 div 用来显示结果的个数let countDiv = document.createElement('div');countDiv.innerHTML = '当前找到 ' + data.length + '个结果!';countDiv.className = 'count';result.appendChild(countDiv);// 这就相当于 java 中的 for each// 此处得到的 item 就会分别代表 data 中的每个元素for (let item of data) {let itemDiv = document.createElement('div');itemDiv.className = 'item';// 构造一个标题let title = document.createElement('a');title.href = item.url;title.innerHTML = item.title;title.target = '_blank';itemDiv.appendChild(title);// 构造一个描述let desc = document.createElement('div');desc.className = 'desc';desc.innerHTML = item.desc;itemDiv.appendChild(desc);// 构造一个 urllet url = document.createElement('div');url.className = 'url';url.innerHTML = item.url;itemDiv.appendChild(url);// 把 itemDiv 加到 .result 中result.appendChild(itemDiv);}}</script>

3.部署到云服务器

我们需要把本地程序,部署到云服务器上,供大家使用,我使用的是腾讯云服务器,值得注意的是,在我们打Jar包之前,我们需要把索引文件也复制到到云服务器中,并修改索引加载路径,只有这样在加载的时候才能找到对应路径。
在这里插入图片描述

4.总结

结果展示:
在这里插入图片描述
在这里插入图片描述

我把所学知识加以利用,完成了搜索引擎这个项目,对于我来说,这个项目最大的难点就是去重重操作,以及进行通过多线程进行优化的时候,即要考虑线程安全问题又要最大限度的实现高并发。

项目网址:http://119.91.235.248:8080/index.html
码云地址:https://gitee.com/thirtythree-code/progect_blog
下期预告:项目日记-博客系统

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

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

相关文章

【Symfony异步任务处理】掌握队列系统的高效之道

标题&#xff1a;【Symfony异步任务处理】掌握队列系统的高效之道 在现代Web应用开发中&#xff0c;处理耗时的任务&#xff08;如发送邮件、处理文件上传等&#xff09;时&#xff0c;队列系统是一种非常有效的方式。Symfony作为一个功能丰富的PHP框架&#xff0c;提供了强大…

c语言--字符串处理之分割strtok

strtok() char *strtok(char s[], const char *delim); 参数&#xff1a; s[]是原字符串&#xff0c;delim为分隔符 返回&#xff1a;字符串拆分后的首地址 第一次拆分&#xff0c;参1 传待拆分的原串。 第1 次拆分时&#xff0c;参1传 NULL. strtok案例解析&#xff1a; #i…

什么是浪涌电压_浪涌电压的种类及保护器件的选型

一、浪涌电压的定义 浪涌电压&#xff0c;也称为浪涌电流&#xff0c;是指电路在遭雷击或在接通、断开电感负载或大型负载时产生的瞬时过电压或过电流。这种瞬变干扰通常发生在极短的时间内&#xff0c;如几百万分之一秒&#xff0c;但峰值电压可能极高&#xff0c;可能达到数…

nginx.conf配置参数解析

nginx配置文件解析 /usr/local/nginx/conf vim /etc/security/limits.conf #配置生效只能重新启动* soft nproc 65535 #能打开的进程最大数是软限制655335,65535是最大值 * hard nproc 65535 * soft nofile 65535 # 进程打开文件数的最大值65535 * hard nof…

ExtendSim在商业和服务行业中的仿真

仿真使企业能够做出明智的、数据驱动的预测&#xff0c;从而指导决策、产生积极成果并建立竞争优势。 精益分析 使用 ExtendSim 中的精益分析方法对欧洲的供应链网络进行建模&#xff0c;一家制造商实现了对最终客户的服务水平提高了 98%&#xff0c;而且现在可以在库存减少约 …

python 实现docx指定语言翻译(不丢失格式)

我这边有个需求需要把一份docx翻译成指定语言的文档并且保存&#xff0c;研究了下&#xff0c;记录。 首先先安装依赖 pip install python-docx1.1.2 googletrans4.0.0rc1 python-docx是用来读取docx的&#xff0c;googletrans使用来翻译的。 googletrans PyPI 这个是官方文…

用Vue3和Rough.js绘制一个交互式3D图

本文由ScriptEcho平台提供技术支持 项目地址&#xff1a;传送门 基于Rough.js和GSAP创建交互式SVG图形卡片 应用场景 本代码适用于需要创建动态交互式SVG图形卡片的场景&#xff0c;例如网页设计、数据可视化和交互式艺术作品。 基本功能 该代码利用Rough.js和GSAP库&…

流批一体计算引擎-13-[Flink]RuntimeExecutionMode和水印策略Watermark Strategy

1 运行时执行模式RuntimeExecutionMode 数据流程序的运行时执行模式。除此之外,它还控制任务 调度、网络洗牌行为和时间语义。一些业务也将发生变化 它们根据配置的执行模式记录发射行为。 (1)RuntimeExecutionMode.STREAMING,管道将使用流语义执行。开始执行之前将部署所有…

Android中android.fg线程和android.ui线程分别代表什么?

Android中android.fg线程和android.ui线程分别代表什么&#xff1f; android.fg线程&#xff08;FgThread&#xff09;&#xff1a; FgThread是Android系统中一个特殊的线程&#xff0c;其类定义大致为public final class FgThread extends ServiceThread。它主要用于提供一个…

gitignore

.gitignore 是一个在 Git 版本控制系统中使用的文件&#xff0c;它用于指定在 Git 仓库中哪些文件或目录应该被忽略&#xff0c;即不会被 Git 追踪或记录。这对于一些自动生成的、用户特定的或敏感的文件特别有用&#xff0c;比如编译后的目标文件、日志文件、配置文件中的密码…

前端学习(五)CSS浮动与补白

目录&#xff1a; 内容&#xff1a; //设置左右浮动 .left{float:left; } .right{float:right; } /*必须设置不同浮动*/ //创建div <div> <dic class"left">左边</div> <div class"right">右边</div> </div> //设置浮…

Spring 异常捕获后依旧回滚

问题抛出 在 Spring 的声明式事务中手动捕获异常&#xff0c;居然判定回滚了&#xff0c;例如 A 里面调用 B &#xff0c;C &#xff0c;C 里面抛出了异常&#xff0c;A 里面对 C 进行了 try catch 依然会回滚&#xff0c;上代码 EnableTransactionManagement SpringBootAppl…

地铁车厢火灾3D模拟逃生演习减少了资源损耗和风险

在消防安全领域&#xff0c;为了更好地提升安全实训效果&#xff0c;我们在VR安全培训领域打造了多款消防安全VR模拟实训系统&#xff0c;不仅实现了与现实世界无异的交互操作&#xff0c;更在虚拟空间中超越了现实的限制&#xff0c;模拟出那些现实中难以搭建的复杂场景。 利用…

mysql:部署MySQL 8.0 环境

mysql网址&#xff1a;MySQL 点击 MySQL Community Server 选择合适的版本 选择8.0版本 下载完成&#xff0c;点击mysql-installer-community-8.0.26.0.msi文件&#xff0c;打开安装向导。 选择自定义安装类型 打开“Select Products” 窗口&#xff0c;可以定制需要安装的产…

成都晨持绪:开一家抖音网店到底能不能赚钱

在数字化时代的浪潮中&#xff0c;抖音以其独特的魅力迅速占领了社交媒体的舞台。众多创业者纷纷把目光投向这个新兴平台&#xff0c;企图在短视频的海洋里找到属于自己的财富岛屿。但是&#xff0c;开一家抖音网店到底能不能赚钱呢? 我们要认识到&#xff0c;抖音作为一个流量…

lt6911UXC 国产原装 高性能HDMI2.0转MIPI DSI / CSI芯片方案 提供LT 开发资料包及在线软硬件技术支持!

1.说明 LT6911UXC是一款高性能HDMI2.0到MIPI DSI / CSI转换器&#xff0c;用于VR&#xff0c;智能电话&#xff0c;显示应用。 HDMI2.0输入支持高达6Gbps的数据速率&#xff0c;从而为4k 60Hz视频提供足够的带宽。还支持HDCP2.2进行数据解密。 对于MIPI DSI / CSI输出&#xf…

【路由交换技术】Cisco Packet Tracer基础入门教程(五)

这一期我们来学习端口聚合&#xff0c;这是针对交换机的技术 前言 不知道大家有没有注意到&#xff0c;我们之前的实验在交换机与交换机之间只用一条线连接&#xff0c;像这样 通过今天的学习&#xff0c;我们要用两条线来连接交换机&#xff0c;就像这样&#xff08;为了能…

人力资源中的人工智能:你应该知道的一切

人工智能已经成为行业讨论更广泛的突出话题。人力资源(HR)对于人力资源专业人士来说&#xff0c;了解这门课程也是如此。除了简要介绍什么是人工智能&#xff0c;以及你可能遇到的主要人工智能类型(或者你可能很快就会遇到它&#xff01;)此外&#xff0c;本文还将探讨人工智能…

10 个实用的 Python 使用技巧

Python 是一门功能强大且易于学习的编程语言&#xff0c;广泛应用于数据科学、机器学习、Web 开发等领域。本文将介绍 10 个实用的 Python 使用技巧&#xff0c;帮助你提升编程效率。 1. 列表生成式 列表生成式&#xff08;List Comprehension&#xff09;是一种简洁的创建列…

教程:Spring Boot中集成Memcached的详细步骤

教程&#xff1a;Spring Boot中集成Memcached的详细步骤 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在现代应用开发中&#xff0c;缓存是提升性能和扩展性…