SSM项目之商铺系统-店铺注册之js实现和店铺类别、区域信息的获取(十一)

本文主要是介绍SSM项目之商铺系统-店铺注册之js实现和店铺类别、区域信息的获取(十一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在都是通过js 完成许多很复杂的功能

我们接下来实现js功能

$(function() {// 获取基本信息的URLvar initUrl = '/storepro/shopadmin/getshopinitinfo';// 注册店铺的URLvar registerShopUrl = '/storepro/shopadmin/registershop';// 调用函数,加载数据getShopInitInfo()// 验证表单输入,省略。。。。/*** 从后台加载获取下拉菜单的值*/function getShopInitInfo() {$.getJSON(initUrl, function(data) {if (data.success) {var tempShopCategoryHtml = '';var tempShopAreaHtml = '';data.shopCategoryList.map(function(item, index) {tempShopCategoryHtml += '<option data-id="'+ item.shopCategoryId + '">' + item.shopCategoryName+ '</option>';});data.areaList.map(function(item, index) {tempShopAreaHtml += '<option data-id="' + item.areaId+ '">' + item.areaName + '</option>';});// 获取html中对应标签的id 赋值$('#shop-category').html(tempShopCategoryHtml);$('#shop-area').html(tempShopAreaHtml)}else{$.toast(data.errMsg);}});};/*** submit按钮触发的操作* 验证表单输入,省略。。。。*/$('#submit').click(function() {// 获取页面的值var shop = {};// 注意: 这个地方的变量名称要和Shop实体类中的属性保持一致,因为后台接收到shopStr后,会将Json转换为实体类,如果不一致会抛出异常// com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException// 如果是编辑,需要传入shopIdshop.shopName = $('#shop-name').val();shop.shopAddr = $('#shop-addr').val();shop.phone = $('#shop-phone').val();shop.shopDesc = $('#shop-desc').val();// 选择id,双重否定=肯定shop.shopCategory = {// 这里定义的变量要和ShopCategory.shopCategoryId保持一致,否则使用databind转换会抛出异常shopCategoryId:$('#shop-category').find('option').not(function(){return !this.selected;}).data('id')};shop.area = {// 这里定义的变量要和Area.areaId属性名称保持一致,否则使用databind转换会抛出异常areaId:$('#shop-area').find('option').not(function(){return !this.selected;}).data('id')};// 图片var shopImg = $('#shop-img')[0].files[0];// 验证码var verifyCodeActual =$('#j_kaptcha').val();if(!verifyCodeActual){$.toast('请输入验证码');return;}// 接收数据var formData = new FormData();// 和后端约定好,利用shopImg和 shopStr接收 shop图片信息和shop信息formData.append('shopImg',shopImg);// 转成JSON格式,后端收到后将JSON转为实体类formData.append('shopStr',JSON.stringify(shop));// 将数据封装到formData发送到后台formData.append('verifyCodeActual',verifyCodeActual);// 利用ajax提交$.ajax({// 动态判断 urlurl:registerShopUrl,type:'POST',data:formData,contentType:false,processData:false,cache:false,success:function(data){if(data.success){$.toast('提示信息:'+data.errMsg);}else{$.toast('提示信息:' + data.errMsg);}// 点击提交后 不管成功失败都更换验证码,防止重复提交$('#kaptcha_img').click();}});});
});

我们实现了两个功能:

1.当我们点开注册商铺页面时,两个下拉框

需要自动从后台提取数据,显示在下拉框交给用户选择,由于我们主要是后台部分,我们在后台给前端提供一个接口,让前台去根据url获取数据,我们看controller方法实现:

思路:获取所有商铺类别写入一个map对象里,交给前端使用

步骤:

第一步:DAO层写一个查找所有商铺类别的接口,并通过mapper文件实现

传入一个商品类别实体类,@Param:这样在xml文件中原本的#{shopCategory}变为#{shopCategoryCondition} 

mapper文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<mapper namespace="storepro.dao.ShopCategoryDao"><select id="queryShopCategory" resultType="shopCategory">SELECTshop_category_id ,shop_category_name,shop_category_desc,shop_category_img,priority,create_time,last_edit_time,parent_idFROMtb_shop_category<where><!--我们查询店铺的话都是查询二级店铺,就是有父类型店铺,一级店铺像是一个选择界面,点击后进入二级界面--><if test="shopCategoryCondition!= null">and parent_id IS  NOT  NULL</if><!--显示父类相同的店铺--><if test="shopCategoryCondition.parent != null">and parent_id=#{shopCategoryCondition.parent.shopCategoryId}</if></where>ORDER BY priorityDESC</select>
</mapper>

方法解释:我们查询了所有店铺类别的所有信息,第一个限定条件是非一级店铺,因为我们的一级店铺更像是一种分类

一级类别:

二级类别才是实体店铺:

第二个限定条件:通过传入的店铺类别,显示相同的父店铺为相同店铺的

获取地区信息的方法之前已经完成,我们直接实现获取店铺类别的方法:

ServiceImpl:

package storepro.service.impl;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import storepro.dao.ShopCategoryDao;
import storepro.entity.ShopCategory;
import storepro.service.ShopCategoryService;import java.util.List;
@Service
public class ShopCategoryServiceImpl implements ShopCategoryService {@AutowiredShopCategoryDao shopCategoryDao;@Overridepublic List<ShopCategory> getShopCategoryList(ShopCategory shopCategoryContidion) {return shopCategoryDao.queryShopCategory(shopCategoryContidion);}
}

没有多余的方法,直接调用Dao层的获取所有店铺类别的方法。

我们看controller层的实现:

package storepro.web.shopadmin;import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartFile;
import org.springframework.web.multipart.commons.CommonsMultipartResolver;
import storepro.dto.ShopExecution;
import storepro.entity.Area;
import storepro.entity.PersonInfo;
import storepro.entity.Shop;
import storepro.entity.ShopCategory;
import storepro.enums.ShopStateEnum;
import storepro.service.AreaService;
import storepro.service.ShopCategoryService;
import storepro.service.ShopService;
import storepro.util.CodeUtil;
import storepro.util.HttpServletRequestUtil;import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.*;@Controller//注解它是一个controller@RequestMapping("/shopadmin")//根url
public class ShopManagementController {@Autowiredprivate ShopService shopService;@Autowiredprivate ShopCategoryService shopCategoryService;@Autowiredprivate AreaService areaService;@RequestMapping(value = "/getshopinitinfo",method = RequestMethod.GET)@ResponseBodyprivate  Map<String, Object> getShopInitInfo() throws JsonProcessingException {Map<String,Object> modelMap=new HashMap<String,Object>();List<ShopCategory> shopCategoryList=new ArrayList<ShopCategory>();List<Area> areaList=new ArrayList<Area>();//ObjectMapper objectMapper=new ObjectMapper();try {shopCategoryList=shopCategoryService.getShopCategoryList(new ShopCategory());areaList=areaService.getAreaList();modelMap.put("shopCategoryList", shopCategoryList);modelMap.put("areaList",areaList);modelMap.put("success",true);}catch (Exception e){modelMap.put("success",false);modelMap.put("errMsg",e.getMessage());//String str=objectMapper.writeValueAsString(modelMap);//return  str;return modelMap;}// String str=objectMapper.writeValueAsString(modelMap);//return  str;return modelMap;}}

controller方法简介:

思路:分别调用areaService和shopCategoryList的实现类的getAreaList()和shopCategoryList()方法,来获得所有二类店铺信息。将他们装入map类型中。并且返回这个map交给前端处理。

这里有个问题卡了我很久

:https://blog.csdn.net/Sunmeok/article/details/81347453

这篇关于SSM项目之商铺系统-店铺注册之js实现和店铺类别、区域信息的获取(十一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象