数据字典的设计--4.DOM对象的ajax应用

  需求:点击下拉选项框,选择一个数据类型,在表单中自动显示该类型下所有的数据项的名称,即数据库中同一keyword对应的所有不重复的ddlName。

    

1.在dictionaryIndex.jsp中添加:

<script type="text/javascript" src="${pageContext.request.contextPath }/script/pub.js"></script>

2.调用js的代码:

function changetype(){

          if(document.Form1.keyword.value=="jerrynew"){

               var textStr="<input type=\"text\" name=\"keywordname\" maxlength=\"50\" size=\"24\"> ";
             document.getElementById("newtypename").innerHTML="类型名称:";
             document.getElementById("newddlText").innerHTML=textStr;

             Pub.submitActionWithForm(‘Form2‘,‘${pageContext.request.contextPath }/system/elecSystemDDLAction_edit.do‘,‘Form1‘);

          }else{

            var textStr="";
            document.getElementById("newtypename").innerHTML="";
            document.getElementById("newddlText").innerHTML=textStr;

            /**
                * 参数一:传递dictionaryIndex.jsp的From2的表单
                * 参数二:传递URL路径地址
                * 参数三:传递dictionaryIndex.jsp的From1的表单

                原理:使用Ajax
                * 传递dictionaryIndex.jsp中表单Form1中的所有元素作为参数,传递给服务器,并在服务器进行处理
                * 将处理后的结果放置到dictionaryEdit.jsp中
                * 将dictionaryEdit.jsp页面的全部内容放置到dictionaryIndex.jsp表单Form2中
            */
            Pub.submitActionWithForm(‘Form2‘,‘${pageContext.request.contextPath }/system/elecSystemDDLAction_edit.do‘,‘Form1‘);
          }
       }

  其中submitActionWithForm方法在pub.js中进行定义。

3.在pub.js中定义5种方法:

  (1)Pub.submitActionWithForm方法

/***
 * domId:表单Form2的名称
 * action:表示URL连接
 * sForm:表单Form1的名称
 */
Pub.submitActionWithForm=function(domId,action,sForm){
  /**第一步:创建Ajax引擎对象*/
  var req = Pub.newXMLHttpRequest();
  /**第二步:req.onreadystatechange表示事件处理函数(相当于一个监听),用来监听客户端与服务器端的连接状态*/
  var handlerFunction = Pub.getReadyStateHandler(req, domId,Pub.handleResponse);
  req.onreadystatechange = handlerFunction;
  /**第三步:打开一个连接,要求:如果是POST请求,需要设置一个头部信息,否则此时不能使用req.send()方法向服务器发送数据*/
  req.open("POST", action, true);
  req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  /**第四步:向服务器发送数据,格式:name=张三&age=28*/
  var str = Pub.getParams2Str(sForm);
  //传递表单Form1中的元素作为参数给服务器
  req.send(str);
}

  (2)Pub.newXMLHttpRequest方法

/**
 * 用于创建ajax引擎
 */
Pub.newXMLHttpRequest=function newXMLHttpRequest() {
  var xmlreq = false;
  if (window.XMLHttpRequest) {
    xmlreq = new XMLHttpRequest();
  } else if (window.ActiveXObject) {

    try {

      xmlreq = new ActiveXObject("Msxml2.XMLHTTP");
    } catch (e1) {

      try {

        xmlreq = new ActiveXObject("Microsoft.XMLHTTP");
      } catch (e2) {

        alert(e2);
      }
    }
  }
  return xmlreq;
}

  xmlreq = new XMLHttpRequest()是Ajax操作的核心对象

  (3)Pub.getParams2Str方法

/**
 * @Description:传递表单Form1中的元素作为参数
 * @param sForm:传递表单Form1的名称
 * @returns {String}:使用ajax返回服务器端的参数,传递的就是表单Form1中元素的参数
 */
Pub.getParams2Str=function getParams2Str(sForm){

 var strDiv="";

 try {
    var objForm=document.forms[sForm];
  if (!objForm)
    return strDiv;
  var elt,sName,sValue;
  for (var fld = 0; fld < objForm.elements.length; fld++) {
      elt = objForm.elements[fld];
      sName=elt.name;
      sValue=""+elt.value;
      if(fld==objForm.elements.length-1)
          strDiv=strDiv + sName+"="+sValue+"";
       else
          strDiv=strDiv + sName+"="+sValue+"&";
   }

  }
  catch (ex) {
    return strDiv;
    }

   return strDiv;
}

  (4)Pub.getReadyStateHandler方法

/**
 * @Description:接收服务器端返回的结果
 * @param req:引擎对象
 * @param eleid:表单Form2的名称
 * @param responseXmlHandler:Pub.handleResponse(函数体)
 * @returns {Function}
 */
Pub.getReadyStateHandler =function getReadyStateHandler(req, eleid,responseXmlHandler) {

  return function () {
    /**
     * req.readyState:用来监听客户端与服务器端的连接状态
     * 0:表示此时客户端没有调用open()方法
     * 1:表示客户端执行open方法,但是send方法没有执行
     * 2:open方法执行,send方法也执行
     * 3:服务器开始处理数据,并返回数据
     * 4:返回数据成功,只有4这个状态,才能获取服务器端返回的结果
     */
    if (req.readyState == 4) {
       /**
        * req.status:表示java的状态码
        * 404:路径错误
        * 500:服务器异常
        * 200:表示没有异常,正常访问数据,只有200这个状态的时候,才能获取服务器端返回的结果
        */
      if (req.status == 200) {
          /**
           * req.responseText:获取服务器端返回的结果,返回的是文本的结果(包括:字符串,json数据)
           * req.responseXML:获取服务器端返回的结果,返回的是XML数据的结果
           */
        responseXmlHandler(req.responseText,eleid);

      } else {
        alert("HTTP error: "+req.status);
        return false;
      }
    }
  }

  (5)Pub.handleResponse方法

/**
 * @Description:将结果返回dictionaryEdit.jsp,并放置到dictionaryIndex.jsp的Form2中
 * @param data:服务器返回的结果
 * @param eleid:表单Form2的名称
 */
Pub.handleResponse= function handleResponse(data,eleid){
      //获取表单Form2的对象
      var ele =document.getElementById(eleid);
      //将返回的结果放置到表单Form2的元素中
      ele.innerHTML = data;

}

  接下来就是对Action类的操作,需要到数据库根据keyword查询相应的ddlName。操作:

  

4.在ElecSystemDDLAction中添加Edit()方法

/**
    * @Name: edit
    * @Description: 跳转到数据字典编辑页面
    * @Parameters: 无
    * @Return: String:跳转到system/dictionaryEdit.jsp
    */
    public String edit(){
        //1.获取数据类型
        String keyword = elecSystemDDL.getKeyword();
        //2.使用数据类型查询数据字典,返回List<ElecSystemDDL>
        List<ElecSystemDDL> list=elecSystemDDLService.findSystemDDLListByKeyword(keyword);
        request.setAttribute("list", list);
        return "edit";
    }

5.IElecSystemDDLService中声明

List<ElecSystemDDL> findSystemDDLListByKeyword(String keyword);

6.ElecSystemDDLServiceImpl中重写方法

/**
    * @Name: findSystemDDLListByKeyword
    * @Description: 根据数据类型名称查询数据字典
    * @Parameters: keyword:数据类型名称
    * @Return: List:存储ElecSystemDDL对象集合
    */
    @Override
    public List<ElecSystemDDL> findSystemDDLListByKeyword(String keyword) {
        //查询条件
        String condition="";
        //查询条件对应的参数
        List<Object> paramsList = new ArrayList<Object>();
        if(StringUtils.isNotBlank(keyword)){
            condition=" and o.keyword=?";
            paramsList.add(keyword);
        }
        //传递可变参数
        Object[] params = paramsList.toArray();
        //排序
        Map<String, String> orderby = new  LinkedHashMap<String, String>();
        orderby.put("o.ddlCode", "asc");
        List<ElecSystemDDL> list = elecSystemDDLDao.findCollectionByConditionNoPage(condition, params, orderby);
        return list;
    }

  其中findCollectionByConditionNoPage(condition, params, orderby)方法是commonDao实现的根据指定条件,返回查询结果集(不分页)的方法

7.dictionaryEdit.jsp遍历对象的值

<%@taglib uri="/struts-tags" prefix="s"%>
<s:if test="#request.list!=null && #request.list.size()>0">
                    <s:iterator value="#request.list">
                        <tr>
                           <td class="ta_01" align="center"  width="20%"><s:property value="ddlCode"/></td>
                           <td class="ta_01" align="center"  width="60%">
                                   <input id="<s:property value="ddlCode"/>" name="itemname" type="text" value="<s:property value="ddlName"/>"  size="45" maxlength="25"></td>
                           <td class="ta_01" align="center"  width="20%">
                                   <a href="#" onclick="delTableRow(‘<s:property value="ddlCode"/>‘)">
                            <img src="${pageContext.request.contextPath }/images/delete.gif" width="16" height="16" border="0" style="CURSOR:hand"></a>
                          </td>
                        </tr>
                    </s:iterator>
                </s:if>
                <s:else>
                    <tr>
                       <td class="ta_01" align="center"  width="20%">1</td>
                       <td class="ta_01" align="center"  width="60%">
                               <input name="itemname" type="text"  size="45" maxlength="25">
                       </td>
                       <td class="ta_01" align="center"  width="20%"></td>
                    </tr>
                </s:else>

  效果展示:

  完成选择类型列表,实现Form2表单的内容替换。

时间: 2024-08-06 03:12:37

数据字典的设计--4.DOM对象的ajax应用的相关文章

电力项目十八--DOM对象的ajax

Ajax操作的核心对象:xmlreq = new XMLHttpRequest(); 第一步:在dictionaryIndex.jsp中添加: <script type="text/javascript" src="${pageContext.request.contextPath }/script/pub.js"></script> 第二步:调用js的代码:实现: Pub.submitActionWithForm: * 参数一:表单Form

js ajax 传送xml dom对象到服务器

客户端代码 1 <script> 2 var isie = true; 3 var xmlhttp = null; 4 function createXMLHTTP() {//创建XMLXMLHttpRequest对象 5 if (xmlhttp == null) { 6 if (window.XMLHttpRequest) { 7 xmlhttp = new XMLHttpRequest(); 8 } 9 else { 10 xmlhttp = new ActiveXObject("

Javascript 解析字符串生成 XML DOM 对象。

Javascript 接收字符串生成 XML DOM 对象.实测对 Firefox .IE6 有效.可用于解析 ajax 的服务器响应结果,也可用于解析自定义字符串.?1. [代码]函数   ppt模版  /** * Parses DOM from XML text.<br /> *  * @author Typhoon.Free.Wolf * @version 2014-02-28_15-51 * @param blDebugFlag *      - Debug flag: true, f

关于用JSON拼凑出来的DOM对象的操作以及EasyUI的提交方式

//关于JSON拼凑出来的DOM对象,不能直接用.class或者#id去找,这样是找不到的.怎么才能找到我也没捉摸出一个具体的规则来.反正多试几种方法就会找出来了,在这里我即用了原生JS//也用的jquery的选择器 //添加右侧流程 function addL(){ var d=$("#dg2").datagrid("getSelected"); var str="<tr><td class='' onclick='TD(this)'

jQuery对象和dom对象

jQuery是一个了不起的轻量级的JavaScript框架,事实上在jQuery发布之前,就已经有无数功能强大得多的JavaScript框架在流行.jQuery的口号是"write less, do more".(选择器,dom操作,jquery-ajax) jQuery是一个了不起的轻量级的JavaScript框架,事实上在jQuery发布之前,就已经有无数功能强大得多的JavaScript框架在流行.从功能列表上来说,jQuery在JavaScript框架中只能算是很不起眼的小弟.

JavaScript基础--DOM对象(十三):(windows对象:history\location\navigator\screen\event)

DOM编程1.为什么要学习DOM(1) 通过dom编程,我们可以写出各种网页游戏(2)dom编程也是ajax的重要基础2.DOM编程介绍DOM = Document Object Model(文档对象模型)DOM是HTML与XML的应用编程接口(API) BOM和DOM相辅相成的关系BOM为纲,DOM为目,DOM是BOM的具体体现 3.DOM对象 3.1 Windows对象 3.1.1 confirm function test(){ var res= window.confirm("你要删除&

应用开发中数据字典项设计实现方案

应用开发中数据字典项设计实现方案 在 应用开发中,总会遇到许多数据字典项,比如对象状态.对象类型等等,这些项一般都是固定的若干可选值选项,比如对象状态可能有新建.修改.删除等状态,这 些数据字典项一旦定义完毕改动的频率非常低:在应用开发中,为了处理方便,一般要对这些数据字典项值选项进行数字编码(例如: 0表示新建,1表示修改,2表示删除等),以方便应用程序中使用.而UI显示对象信息时不能显示对象状态等的编码,对于编码值设计人员知道代表什么意思,但用户就不明白了,所以需要进行编码转换,从编码转换为

WebKit JavaScript Binding添加新DOM对象的三种方式

一.基础知识 首先WebKit IDL并非完全遵循Web IDL,只是借鉴使用.WebKit官网提供了一份说明(WebKitIDL),比如Web IDL称"operation”(操作), 而WebKitIDL称为"method"(方法), 另外Web IDL也不像WebKitIDL那样将属性和参数分开. 为JavaScript绑定对象,可以使用module来定义所从属的模组. 典型的module包括: core, window, event, traversal, range

IE与FireFox的DOM对象树差异

 最近在做项目,有复习一下以前JS的关于DOM的知识点,再次小小的总结一下. 以下是DOM对象在IE与FireFox中的一些小区别,就当积累吧. 1.IE会把没有在文档中定义的属性也加入DOM树 2.IE不会把title中的文本内容加入DOM树 3.IE会把换行缩进信息过滤掉,firefox则会认为是有用的文本内容,并作为文本节点的一部分加入DOM树 4.IE不会把Script标签中的内容加入DOM树,FireFox将里面的内容加入DOM树