`
guohui_fz
  • 浏览: 56219 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

dwr操作form表单Select/option,table

阅读更多

util.js包含一些有用的函数function,用于在客户端页面调用.

主要功能如下:

代码

  1. 1、$() 获得页面参数值   
  2. 2、addOptions and removeAllOptions 初始化下拉框   
  3. 3、addRows and removeAllRows   填充表格   
  4. 4、getText   取得text属性值   
  5. 5、getValue 取得form表单值   
  6. 6、getValues 取得form多个值   
  7. 7、onReturn     
  8. 8、selectRange   
  9. 9、setValue   
  10. 10、setValues   
  11. 11、toDescriptiveString   
  12. 12、useLoadingMessage   
  13. 13、Submission box  

 

代码

  1. 1、$()函数   
  2.    IE5.0 不支持   
  3.    $ = document.getElementById   
  4.    取得form表单值   
  5.    var name = $("name");  

 

代码

  1. a、如果你想在更新select 时,想保存原来的数据,即在原来的select中添加新的option:   
  2.      var sel = DWRUtil.getValue(id);   
  3.      DWRUtil.removeAllOptions(id);   
  4.      DWRUtil.addOptions(id,...);   
  5.      DWRUtil.setValue(id,sel);   
  6.      demo:比如你想添加一个option:“--请选择--”   
  7. DWRUtil.addOptions(id,["--请选择--"]);   
  8.   
  9.     DWRUtil.addOptions()有5中方式:  

 

代码

  1. @ Simple Array Example: 简单数组   
  2.      例如:   
  3.      Array array = new Array[ 'Africa', 'America', 'Asia', 'Australasia', 'Europe' ];   
  4.      DWRUtil.addOptions("demo1",array);  

 

代码

  1. @ Simple Object Array Example 简单数组,元素为beans   
  2.        这种情况下,你需要指定要显示 beans 的 property 以及 对应的 bean 值   
  3.        例如:   
  4.         public class Person {   
  5.       private String name;   
  6.       private Integer id;   
  7.       pirvate String address;   
  8.       public void set(){……}   
  9.       public String get(){……}   
  10.         }   
  11.         DWRUtil.addOptions("demo2",array,'id','name');   
  12.         其中id指向及bean的id属性,在optiong中对应value,name指向bean的name属性,对应下拉框中显示的哪个值.  

 

代码

  1. @ Advanced Object Array Example 基本同上   
  2.      DWRUtil.addOptions( "demo3",   
  3.                  [{ name:'Africa', id:'AF' },   
  4.                   { name:'America', id:'AM' },   
  5.                   { name:'Asia', id:'AS' },   
  6.                   { name:'Australasia', id:'AU' },   
  7.                   { name:'Europe', id:'EU' }   
  8.          ],'id','name');  

 

代码

  1. @ Map Example 用制定的map来填充 options:   
  2.         如果 server 返回 Map,呢么这样处理即可:   
  3.         DWRUtil.addOptions( "demo3",map);   
  4.         其中 value 对应 map keys,text 对应 map values;  

 

代码

  1. @ <ul> and <ol> list editing   
  2.         
  3.         DWRUtil.addOptions() 函数不但可以填出select,开可以填出<ul>和<ol>这样的heml元素  

 

3、addRows and removeAllRows 填充表格

DWR 提供2个函数来操作 table;

----------------------------

DWRUtil.addRows(); 添加行

----------------------------

DWRUtil.removeAllRows(id); 删除指定id的table

----------------------------

下面着重看一下 addRows() 函数:

DWRUtil.addRows(id, array, cellfuncs, [options]);

其中id 对应 table 的 id(更适合tbodye,推荐使用 tbodye)

array 是server端服务器的返回值,比如list,map等等

cellfuncs 及用返回值来天春表格

[options] 用来设置表格样式,它有2个内部函数来设置单元格样式(rowCreator、cellCreator)。

比如: server端返回list,而list中存放的是下面这个 bean:

代码

  1.        public class Person {   
  2. private String name;   
  3. private Integer id;   
  4. pirvate String address;   
  5. public void set(){……}   
  6. public String get(){……}   
  7.       }  

 

下面用 DWRUtil.addRows();

代码

  1.     function userList(data){   
  2.      //var delButton = "<input type='button'/>";   
  3.      //var editButton = "<input type='button'/>";   
  4.      var cellfuncs = [   
  5.          function(data){return data.id;},   
  6.          function(data){return data.userName;},   
  7.          function(data){return data.userTrueName;},   
  8.          function(data){return data.birthday;},   
  9.          function(data){   
  10.          var idd = data.id;   
  11. var delButton = document.createElement("<INPUT TYPE='button' onclick='delPerson("+ idd +")'>");   
  12.              delButton.setAttribute("id","delete");   
  13.              delButton.setAttribute("value","delete");   
  14.              return delButton;   
  15.          },   
  16.          function(data){   
  17.              var idd = data.id;   
  18.              var editButton = document.createElement("<INPUT TYPE='button' onclick='editPerson("+ idd +")'>");   
  19.              editButton.setAttribute("name","edit");   
  20.              editButton.setAttribute("value","edit");               
  21.              return editButton;   
  22.          }   
  23.      ];   
  24.      DWRUtil.removeAllRows('tabId');   
  25.      DWRUtil.addRows('tabId', data,cellfuncs,{   
  26.      rowCreator:function(options) {   
  27.          var row = document.createElement("tr");   
  28.          var index = options.rowIndex * 50;   
  29.          row.setAttribute("id",options.rowData.id);   
  30.          row.style.collapse = "separate";   
  31.          row.style.color = "rgb(" + index + ",0,0)";   
  32.          return row;   
  33.      },   
  34.      cellCreator:function(options) {   
  35.          var td = document.createElement("td");   
  36.          var index = 255 - (options.rowIndex * 50);   
  37.          //td.style.backgroundColor = "rgb(" + index + ",255,255)";   
  38.          td.style.backgroundColor = "menu";   
  39.          td.style.fontWeight = "bold";   
  40.          td.style.align = "center";   
  41.          return td;   
  42.      }          
  43.      });   
  44.      document.getElementById("bt").style.display = "none";   
  45.       }  

 

4、getText 取得text属性值

DWRUtil.getText(id): 用来获得 option 中的文本

比如:

代码

  1.        <select id="select">  
  2. <option   value="1"> 苹果 </option>  
  3. <option   value="2" select> 香蕉 </option>  
  4. <option   value="3"> 鸭梨 </option>  
  5.        </select>  

 

调用 DWRUtil.getText("select"); 将返回 "香蕉" 字段;

DWRUtil.getText(id);仅仅是用来获得 select 文本值,其他不适用。

5、DWRUtil.getValue(id): 用来获得 form 表单值

有如下几种情况:

代码

  1.       Text area (id="textarea"): DWRUtil.getValue("textarea")将返回 Text area的值;   
  2. Selection list (id="select"): DWRUtil.getValue("select") 将返回 Selection list 的值;   
  3. Text input (id="text"): DWRUtil.getValue("text") 将返回 Text input 的值;   
  4. Password input (id="password"): DWRUtil.getValue("text") 将返回 Password input 的值;   
  5. Form button (id="formbutton"): DWRUtil.getValue("formbutton") 将返回 Form button 的值;   
  6. Fancy button (id="button"): DWRUtil.getValue("formbutton") 将返回 Fancy button 的值;  

 

6、getValues 取得form多个值

批量获得页面表单的值,组合成数组的形式,返回 name/value;

例如: form():

代码

  1.      <input type="textarea" id="textarea" value="1111"/>  
  2.       <input type="text" id="text" value="2222"/>  
  3.       <input type="password" id= "password" value="3333"/>  
  4.       <select id="select">  
  5. <option   value="1"> 苹果 </option>  
  6. <option   value="4444" select> 香蕉 </option>  
  7. <option   value="3"> 鸭梨 </option>  
  8.        </select>  
  9.       <input type="button" id="button" value="5555"/>  
  10.         
  11.       那么: DWRUtil.getValues({textarea:null,select:null,text:null,password:null,button:null})   
  12.       将返回   ^^^^^^^^^^^^^^^^{textarea:1111,select:4444,text:2222,password:3333,button:5555}  

 

7、DWRUtil.onReturn 防止当在文本框中输入后,直接按回车就提交表单。

<input type="text" onkeypress="DWRUtil.onReturn(event, submitFunction)"/>

<input type="button" onclick="submitFunction()"/>

8、DWRUtil.selectRange(ele, start, end);

在一个input box里选一个范围

代码

  1. DWRUtil.selectRange("sel-test", $("start").value, $("end").value);   
  2.   
  3. 比如:<input type="text" id="sel-test" value="012345678901234567890">   
  4.   
  5. DWRUtil.selectRange("sel-test", 2, 15);  

 

9、DWRUtil.setValue(id,value);

为指定的id元素,设置一个新值;

10、DWRUtil.setValues({

name: "fzfx88",

password: "1234567890"

}

); 同上,批量更新表单值.

/***********************************************************************/

11、DWRUtil.toDescriptiveString()

带debug信息的toString,第一个为将要debug的对象,第二个参数为处理等级。等级如下:

0: Single line of debug 单行调试

1: Multi-line debug that does not dig into child objects 不分析子元素的多行调试

2: Multi-line debug that digs into the 2nd layer of child objects 最多分析到第二层子元素的多行调试

<input type="text" id="text">

DWRUtil。toDescriptiveString("text",0);

/******************************************************************************/

12、DWRUtil.useLoadingMessage();

当发出ajax请求后,页面显示的提示等待信息;

代码

  1.     function searchUser(){   
  2. var loadinfo = "loading....."  
  3. try{   
  4.      regUser.queryAllUser(userList);   
  5.      DWRUtil.useLoadingMessage(loadinfo);           
  6. }catch(e){   
  7.   
  8. }   
  9.     }
分享到:
评论

相关推荐

    DWR 处理各种form表单Selectoption,table.doc

    DWR 处理各种 form 表单 Select/option,table DWR(Direct Web Remoting)是一种基于 Ajax 的远程调用技术,用于简化 JavaScript 与服务器之间的交互。DWR 可以将服务器端的 Java 对象转换为 JavaScript 对象,使得...

    DWR 处理各种form表单

    讲解DWR 框架的使用,和各种form表单Select-option,table

    DWR联动刷select

    &lt;script type='text/javascript' src='/Study_DWR_Select/dwr/interface/FlushSelect.js'&gt;&lt;/script&gt; &lt;script type='text/javascript' src='/Study_DWR_Select/dwr/engine.js'&gt;&lt;/script&gt; &lt;script type='text/...

    dwr20.dtd约束文件

    dwr20.dtd约束文件。 &lt;!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://www.getahead.ltd.uk/dwr/dwr20.dtd" &gt;

    dwr-1.13.jar及dwr.xml

    DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr//dwr10.dtd"&gt; &lt;br/&gt;dwr-2.0&lt;br/&gt;&lt;!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web ...

    dwr相关配置笔记 代码说明

    这样,所有以`/dwr/*`开头的URL请求都将被DWRServlet处理。例如: ```xml &lt;servlet-name&gt;dwr-invoker&lt;/servlet-name&gt; &lt;servlet-class&gt;uk.ltd.getahead.dwr.DWRServlet&lt;/servlet-class&gt; &lt;/servlet&gt; ...

    DWR(包括engine.js+util.js).rar

    这个压缩包包含了DWR的核心组件`engine.js`和辅助库`util.js`,它们是实现DWR功能的关键。 `engine.js`是DWR的核心脚本,它实现了JavaScript和Java之间的远程调用(Remote Procedure Calls, RPC)。这个文件处理了...

    Dwr 表单提交 时间类型

    标题 "Dwr 表单提交 时间类型" 涉及的是Direct Web Remoting (DWR)框架中的一个关键概念,即如何处理表单提交时的时间数据类型。DWR是一种允许JavaScript与服务器端Java代码进行交互的技术,使得Web应用能够实现动态...

    dwr源码包,dwr.jar包下载

    1、 导入dwr.jar包 2、 在web.xml中配置dwr,如下: &lt;!-- 配置DWR --&gt; &lt;servlet-name&gt;dwr-invoker&lt;/servlet-name&gt; org.directwebremoting.servlet.DwrServlet ... &lt;url-pattern&gt;/dwr/*&lt;/url-pattern&gt;

    AJAX DWR教程

    在提供的资源中,"DWR util_js 整理(DWR 处理各种form表单Select-option,table等,List,Bean - Bob@CSDN - CSDN博客.htm"可能是一个详细的博客文章,讲解了如何使用DWR处理表单和数据。"ajax+DWR+实战.pdf"则可能是更...

    DWR 框架使用手册

    &lt;url-pattern&gt;/dwr/*&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; ``` 2. **DWR配置文件(dwr.xml)**:这是DWR的配置中心,用于声明哪些Java类和方法可以被JavaScript访问。默认情况下,DWR会查找`WEB-INF/dwr.xml`,但...

    dwr实现select列表的动态级联

    在“dwr实现select列表的动态级联”这个场景中,DWR将被用来实现在前端JavaScript和后端Java之间的数据同步,以便在用户选择上级选项时动态更新下级选项列表。以下是实现这个功能的关键步骤: 1. **设置DWR配置**:...

    dwr自己配置一个实例

    &lt;?xml version="1.0" encoding="UTF-8"?&gt; &lt;!DOCTYPE dwr PUBLIC ... "http://getahead.org/dwr/dwr30.dtd"&gt; &lt;dwr&gt; &lt;param name="class" value="com.dwr.bean.Hello" /&gt; &lt;/create&gt; &lt;/allow&gt; &lt;/dwr&gt;

    Dwr入门操作手册Dwr

    Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr入门操作手册Dwr...

    一个DWR实现table的小例子

    这个例子展示了DWR如何简化Web应用中的数据获取和显示过程,同时也揭示了如何结合使用DWR和SQL Server 2005来处理数据库操作。通过这种方式,开发者可以创建更动态、响应式的Web界面,提高用户的交互体验。记住,DWR...

    DWR的配置和传值DWR的配置和传值

    这样的配置会将所有以`/dwr/`开头的URL映射到DWRServlet。 2. **调试模式**: 如果你想开启DWR的调试模式,可以在Servlet配置中添加初始化参数`debug`,并设置其值为`true`: ```xml &lt;param-name&gt;debug&lt;/...

    DWR教程

    这样,所有以`/dwr/`开头的URL请求都会被DWRServlet处理。 #### 1.2 调试模式 如果想要启用DWR的调试模式,可以在Servlet配置中添加`debug`参数: ```xml &lt;param-name&gt;debug&lt;/param-name&gt; &lt;param-value&gt;true&lt;/...

    DWR中各种java方法的调用

    &lt;url-pattern&gt;/dwr/*&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; ``` ##### 2. 使用Debug/Test模式 为了调试和测试目的,DWR提供了debug模式。通过在servlet配置中添加`&lt;init-param&gt;`元素并设置`debug`参数为`true`,可以...

    spring使用annotation整合dwr笔记

    &lt;url-pattern&gt;/dwr/*&lt;/url-pattern&gt; &lt;/servlet-mapping&gt; ``` - **配置Spring上下文**:定义Spring的配置文件位置,并启用Spring的上下文加载监听器。 ```xml &lt;!-- Spring上下文配置 --&gt; &lt;param-name&gt;...

Global site tag (gtag.js) - Google Analytics