旅游网小案例:旅游线路的详情展示

2023-10-09 17:50

本文主要是介绍旅游网小案例:旅游线路的详情展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分析

  • 效果分析
    在这里插入图片描述根据页码数据进行分析,找到对应数据的表,初步完成dao层的分析.
  • 流程分析
    在这里插入图片描述进行流程分析,对业务的流程进行粗略分析,掌握功能的整体执行流程.

进行代码编写

  • js
		//线路详细获取//获取ridvar rid = getParameter("rid");//发送请求route/findOne$.post("route/findOne", {rid: rid}, function (route) {//填充数据到html$(".rname").html(route.rname);$("#routeIntroduce").html(route.routeIntroduce);$("#price").html("¥" + route.price);$("#sname").html(route.seller.sname);$("#consphone").html(route.seller.consphone);$("#address").html(route.seller.address);//设置收藏次数$("#favoriteCount").html("已收藏" + route.count + "次");//图片展示进行拼接var ddstr = '<a class="up_img up_img_disable"></a>';var imgList = route.routeImgList;$("#dt").html('<img alt="" class="big_img"\n' +'                     src="' + imgList[0].bigPic + '">');for (var i = 0; i < imgList.length; i++) {var astr;if (i >= 4) {astr = '<a title="" class="little_img"\n' +'                   data-bigpic="' + imgList[i].bigPic + '" style="display:none;">\n' +'                    <img src="' + imgList[i].smallPic + '">\n' +'                </a>';} else {astr = '<a title="" class="little_img"\n' +'                   data-bigpic="' + imgList[i].bigPic + '">\n' +'                    <img src="' + imgList[i].smallPic + '">\n' +'                </a>';}ddstr += astr;}ddstr += '<a class="down_img down_img_disable" style="margin-bottom: 0;"></a>';//进行切换样式的加载goImg();});//进行收藏状态获取和刷新flush();

对html进行处理,将真实数据填充到页面.

  • Servlet
/*** 根据id查询一个旅游线路的详细信息** @param request* @param response* @throws ServletException* @throws IOException*/public void findOne(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//接收idString rid = request.getParameter("rid");//调用service方法Route route = routeService.findOne(rid);//回写writeValue(route, response);}

进行数据的获取和回写,并调用service方法

  • Service
 public Route findOne(String rid) {if (rid != null && !"".equals(rid)) {//根据rid查询routeRoute route = routeDao.findOne(rid);//根据route的rid查询图片List<RouteImg> routeImgs = routeImgDao.findByRid(route.getRid());//注入routeImgList数据route.setRouteImgList(routeImgs);//根据route的sid查询商家信息Seller seller = sellerDao.findById(route.getSid());//注入seller数据route.setSeller(seller);return route;}return null;}

将数据进行获取,并填充到Route类中.
在这里插入图片描述
根据表结构分析,查询条件,得到相应是数据,根据rid查询tab_route表,得到单个线路route信息,根据route表中sid查询tab_selle得到对应商家信息,根据rid在tab_route_img查询,得到的图片路径.(事实证明满足第三范式和根据表关系建立主外键,能够更科学的设计表)

  • Dao
@Overridepublic Route findOne(String rid) {String sql = "select * from tab_route where rid= ?";return template.queryForObject(sql, new BeanPropertyRowMapper<>(Route.class), rid);}
@Overridepublic List<RouteImg> findByRid(int rid) {String sql = "select * from tab_route_img where rid=? ";return template.query(sql, new BeanPropertyRowMapper<>(RouteImg.class), rid);}
@Overridepublic Seller findById(int sid) {String sql = "select * from tab_seller where sid=?";return template.queryForObject(sql, new BeanPropertyRowMapper<>(Seller.class), sid);}

由于存在于不同的类中,所以分开放,都是简单的查询方法.

这篇关于旅游网小案例:旅游线路的详情展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/174531

相关文章

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

MySQL不使用子查询的原因及优化案例

《MySQL不使用子查询的原因及优化案例》对于mysql,不推荐使用子查询,效率太差,执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响,本文给大家... 目录不推荐使用子查询和JOIN的原因解决方案优化案例案例1:查询所有有库存的商品信息案例2:使用EX

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、