一,前台数据

 $.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)动态加载数据。的更多相关文章

  1. AppCan学习笔记----关闭页面listview动态加载数据

    AppCan页面关闭 AppCan 的页面是由两个HTML组成,如果要完全关闭的话需要在主HTML eg.index.html中关闭,关闭方法:appcan.window.close(-1); 管道 ...

  2. [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件

    页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...

  3. 微信小程序(五) 利用模板动态加载数据

    利用模板动态加载数据,其实是对上一节静态数据替换成动态数据:

  4. mui 动态加载数据出现的问题处理 (silder轮播组件 indexedList索引列表 下拉刷新不能继续加载数据)

    mui-slider 问题:动态给mui的图片轮播添加图片,轮播不滚动. 解决:最后把滚动轮播图片的mui(".mui-slider").slider({interval: 300 ...

  5. ASP.NET MVC动态加载数据

    ASP.NET MVC动态加载数据,一般的做法是使用$.each方法来循环产生tabel: 你可以在html时先写下非动态的部分:  Source Code 上图中,有一行代码: <tbody ...

  6. js实现滚动条来动态加载数据

    主要angular2+es6 data:Array<any> //展示的数据 allData:Array<any> //全部的数据 size:number = 10 //每次动 ...

  7. js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的

    js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样 ...

  8. js动态加载数据并合并单元格

    js动态加载数据合并单元格, 代码如下所示,可复制直接运行: <!DOCTYPE HTML> <html lang="en-US"> <head> ...

  9. 爬虫--selenuim和phantonJs处理网页动态加载数据的爬取

    1.谷歌浏览器的使用 下载谷歌浏览器 安装谷歌访问助手 终于用上谷歌浏览器了.....激动 问题:处理页面动态加载数据的爬取 -1.selenium -2.phantomJs 1.selenium 二 ...

随机推荐

  1. HDU 6181 Two Paths

    这是一道次短路的题 但是本题有两个坑 注意边权的范围,一定要在所有与距离有关的地方开 long long 本题所求的并不是次短路,而是与最短路不同的最短的路径,如果最短路不止一条,那么就输出最短路的长 ...

  2. MUI体验框架

    1.      mui简介 1.1  缘起 1.基于jq的jqmobile,性能低的无法忍受,且UI难看 2.bootstrap这种响应式设计,性能在低端机不足,而且UI风格一看就是网页,不是App的 ...

  3. 常用VI操作命令

    # ------------------- VI basic ------------------------------- # file name: VI_basic # author : # da ...

  4. SmokePing 部署实践

    1 通过 yum 安装依赖的库以及环境 yum install rrdtool wqy* fping curl bind-utils httpd httpd-devel \ perl perl-FCG ...

  5. python学习:收集主机信息

    #!/usr/bin/env python   from subprocess import Popen, PIPE   def getIfconfig():     p = Popen(['ifco ...

  6. Linux终端下 dstat 监控工具

    dstat 是一个可以取代vmstat,iostat,netstat和ifstat这些命令的多功能产品.dstat克服了这些命令的局限并增加了一些另外的功能,增加了监控项,也变得更灵活了.dstat可 ...

  7. js获取对象长度和名称

    1.对象的长度不能用.length获取,用js原生的Object.keys可以获取到 var obj = {'name' : 'Tom' , 'sex' : 'male' , 'age' : '14' ...

  8. vector动态数组

    vector是STL模板库中的序列式容器,利用它可以有效地避免空间的浪费. 创建vector容器 vector< int >v:vector< char >:vector< ...

  9. BUNOJ 1011

    字符串处理的题.原题链接 AC代码: #include<cstring> #include<cstdio> #include<string> #include< ...

  10. UVA-818 dfs + 位运算

    暴力枚举一些圆环,将这些圆环解开,看能否成为单链.判断单链的三个条件: 除了这些删除的圆环之外,其他圆环还连接着的圆环不能超过两个. 剩下的环没有连成圈. 剩下的圆环共分成m堆,每堆之间无连接,m必须 ...