通过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 二 ...
随机推荐
- [Android] Toast问题深度剖析(二)
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者: QQ音乐技术团队 题记 Toast 作为 Android 系统中最常用的类之一,由于其方便的api设计和简洁的交互体验,被我们所广泛采用 ...
- mysql必知必会
春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...
- [Python Study Notes]计算cpu使用率v0.1
V0.1 更新日志: 1.加入平台判断,支持windows与linux 2.自动清屏显示,显示更加直观 '''''''''''''''''''''''''''''''''''''''''''''''' ...
- 用Markdown写微信公众号文章
目前微信公众号的编辑器是不支持Markdown语法的,那怎么办呢? 有一款叫Markdown Here的插件可以解决这个问题(支持Chrome.Firefox.Safari). 官方网站:http:/ ...
- gitlab项目迁移
ALL Git* => Gitlab Nothing, Just copy the git URL to gitlab(类似于 fork) 使用 Git Mirror 無痛轉移 Git Serv ...
- go入门
1.hello world 小程序 package main import "fmt" func main() { fmt.println("hello,世界" ...
- Python基本格式化输出
什么叫格式化输出? 数据按照某种特殊的要求输出 假如输入一个整数,希望整数按照十六进制,八进制输出,如果输入一个小数,希望小数保留后面2位数然后输出,或者以科学计数法的方式来输出小数.字符串的输出希望 ...
- .NET常用第三方库(包)总结
文章会不定期更新,以下内容均为个人总结,欢迎各位拍砖指正 序列化与反序列化 JSON.NET应该是.NET平台上使用最为广泛的序列化/反序列化包了,ASP.NET和ASP.NET Core中默认序列化 ...
- 机器学习03:K近邻算法
本文来自同步博客. P.S. 不知道怎么显示数学公式以及排版文章.所以如果觉得文章下面格式乱的话请自行跳转到上述链接.后续我将不再对数学公式进行截图,毕竟行内公式截图的话排版会很乱.看原博客地址会有更 ...
- POI导出EXCEL,浏览器不兼容,文件名称乱码,文件无法打开解决方法