通过ApplicationContext.getBean(beanName)动态加载数据。
一,前台数据
$.ajax({ url: '/intra/coe/order/ploadTable.htm', type: 'POST', dataType: 'json',
data: {keyId:$("#key_keyId").val(),beanName:'cpAssetsModify',},
关键注意这个url
二,到后台的代码
(会默认的找到这个index方法,配置文件设置的)
@SuppressWarnings("unchecked") public void index(HttpServletRequest request, HttpServletResponse response) { String keyId = request.getParameter("keyId"); String beanName = request.getParameter("beanName"); String tableHead = request.getParameter("tableHead"); String tableName = request.getParameter("tableName"); LoadTableService loadTableService = ApplicationContext.getBean(beanName); List<Map<String, Object>> headLst = getTableHead(tableHead); if(headLst==null||headLst.size()==0){ headLst = loadTableService.getHeadList(keyId); } Map<String, Object> tableInfo = new HashMap<String, Object>(); tableInfo.put("tableName", tableName); List<Map<String, Object>> bodyLst = (List<Map<String, Object>>) loadTableService.getBodyList(keyId,tableInfo);
上面的
ApplicationContext.getBean(beanName);
会把前台获取的这个bean去配置文件找,注意这个是application容器,所以就会去所有的已经加载的xml文件里面去找,包括jar包里面的xml文件
会找到下面的配置文件
<bean id="cpAssetsModify" class=" com.bill99.seashell.boss.appcontroller.intra.product.AssetsCPModifyControler"> <property name="methodNameResolver"> <ref bean="paramResolver" /> </property> <property name="merchantAccountService" ref="merchantAccountService"/> <property name="merchantInfoService" ref="merchantInfoService"/> <property name="workorderDetailService" ref="workorderDetailService"/> <property name="dynamicBuildProductClient" ref="dynamicBuildProductClient"/> </bean>
这个时候返会的就是
AssetsCPModifyControler这个类的一个代理对象,注意上面的index方法是公共的,但是这个时候假如把beanname为cpAssetsModify传过来找到对应的类AssetsCPModifyControler
loadTableService.getBodyList(keyId,tableInfo);实质上就是
AssetsCPModifyControler.getBodyList(keyId,tableInfo)了。
三,接口及实现类
public List<Map<String, Object>> getBodyList(String keyId,Map<String, Object> tableInfo);
上面的就是接口了。
public class AssetsCPModifyControler extends IntraProductBaseControler implements LoadTableService{ @Override public List<Map<String, Object>> getBodyList(String keyId,Map<String, Object> tableInfo) { List<Map<String, Object>> resultList = new ArrayList<Map<String, Object>>(); WorkorderDetail wd = workorderDetailService.findWorkorderDetailById(keyId); String jsonStr = wd.getProductParam(); if(!StringUtil.isEmpty(jsonStr)){ try { Map<String, Object> productMap = JsonUtils.json2Map(jsonStr); if(productMap.get("productList") != null){ List<Map<String,Object>> productList = (List)productMap.get("productList"); //获得cp下面的终端 getAddTerminals(resultList,productList); //获得变更的终端 和 资产下面的终端 getUpdateTerminals(resultList, productList); int terminalNo=1; for (Map<String, Object> terminalMap : resultList) { terminalMap.put("terminalNo", terminalNo); terminalNo++; } } } catch (Exception e) { logger.error("json2Map异常", e); } } return resultList; }
这个是实现类,在这就可以操作了。
以上就是通过
ApplicationContext.getBean(beanName)
动态的加载的一种方式。
通过ApplicationContext.getBean(beanName)动态加载数据。的更多相关文章
- AppCan学习笔记----关闭页面listview动态加载数据
AppCan页面关闭 AppCan 的页面是由两个HTML组成,如果要完全关闭的话需要在主HTML eg.index.html中关闭,关闭方法:appcan.window.close(-1); 管道 ...
- [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件
页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...
- 微信小程序(五) 利用模板动态加载数据
利用模板动态加载数据,其实是对上一节静态数据替换成动态数据:
- mui 动态加载数据出现的问题处理 (silder轮播组件 indexedList索引列表 下拉刷新不能继续加载数据)
mui-slider 问题:动态给mui的图片轮播添加图片,轮播不滚动. 解决:最后把滚动轮播图片的mui(".mui-slider").slider({interval: 300 ...
- ASP.NET MVC动态加载数据
ASP.NET MVC动态加载数据,一般的做法是使用$.each方法来循环产生tabel: 你可以在html时先写下非动态的部分: Source Code 上图中,有一行代码: <tbody ...
- js实现滚动条来动态加载数据
主要angular2+es6 data:Array<any> //展示的数据 allData:Array<any> //全部的数据 size:number = 10 //每次动 ...
- js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的
js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样 ...
- js动态加载数据并合并单元格
js动态加载数据合并单元格, 代码如下所示,可复制直接运行: <!DOCTYPE HTML> <html lang="en-US"> <head> ...
- 爬虫--selenuim和phantonJs处理网页动态加载数据的爬取
1.谷歌浏览器的使用 下载谷歌浏览器 安装谷歌访问助手 终于用上谷歌浏览器了.....激动 问题:处理页面动态加载数据的爬取 -1.selenium -2.phantomJs 1.selenium 二 ...
随机推荐
- BZOJ 4318: OSU! [DP 概率]
传送门 题意:变成了告诉每个操作的成功概率,并且得分是三次方 一样....分别维护$x,\ x^2,\ x^3$的期望就行了 注意$x^3$是我们最终求的得分,即使失败得分也要累加上之前的 #incl ...
- SDN第三次上机作业
作业链接 1.创建以下拓扑(可采用任意方式) 2.利用OVS命令下发流表,实现VLAN功能 3.利用OVS命令查看流表 4.验证性测试 5.Wireshark抓包验证
- H5动画
1.参考:http://blog.csdn.net/whqet/article/details/42911059?readlog https://developer.mozilla.org/zh-CN ...
- User Parameters(用户参数)
User Parameters(用户参数),这个是整个zabbix的重点 Zabbix有很多内置的itemkey,但是这些key都是由Zabbix定义好的比较通用的监控项的实现, 如果我们自己想实 ...
- python中常见的三种句型if,while,for
1.if语句: 特别说明:条件后面的冒号不能少,同样必须是英文字符. 特别特别说明:if内部的语句需要有一个统一的缩进,一般用4个空格.python用这种方法替代了其他很多编程语言中的{}. num= ...
- Promise对象的简单用法
要了解一个东西,首先要从,它是什么.用来做什么以及怎么取用它这三个方面来了解. 首先,promise是什么? 我们来参考一下MDN对它的定义: Promise 对象用于一个异步操作的最终完成(或失败) ...
- php+redis 学习 一 连接
<?php header('content-type:text/html;chaeset=utf-8'); $redis = new Redis(); $redis->connect('1 ...
- 加入GIMPS项目,寻找梅森素数!
截止到目前为止人类共找到了50个梅森素数,其中最后16个梅森素数都是通过GIMPS项目找到的. 为了激励人们寻找梅森素数和促进网格技术发展,总部设在美国旧金山的电子前沿基金会(EFF)于1999年3月 ...
- appium+Python 启动app(一)
当我们appium和Python环境都配置好了,如何启动我们第一个app呢?下面介绍appium+Python启动app的操作步骤,为了能够详细查看,我们这里使用夜游神模拟器进行示范. 测试项目:QQ ...
- git一键部署代码到远程服务器(linux)(采坑总结)
原来一直使用FileZilla来代码部署,去年使用git,代码版本管理,真TM好用,一起回顾下历程! 一. 代码部署方式及思路: 1. 使用FTP/SFTP工具,上传代码 2. git人工部署.1. ...