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

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配