思路:使用jquery-easyui框架实现弹出div,在jsp初始化时从后台获得数据初始化div中的form表单元素的value属性,从而获得后台数据。在点击确定按钮时使用ajax向后台发送数据。

步骤:

  1、jsp页面引入如下文件

      <link rel="stylesheet" type="text/css" href="<c:url value="/jquery-easyui-1.3.2/themes/gray/easyui.css"/>"/>
      <link rel="stylesheet" type="text/css" href="<c:url value="/jquery-easyui-1.3.2/themes/icon.css"/>"/>
      <script type="text/javascript" src="/jquery-easyui-1.3.2/jquery-1.8.0.min.js"></script>
       <script type="text/javascript" src="/jquery-easyui-1.3.2/jquery.easyui.min.js"></script>
      <script type="text/javascript" src="/jquery-easyui-1.3.2/locale/easyui-lang-zh_CN.js" charset="utf-8"></script>

2、在create.jsp页面上添加弹出div

  <div id="generateProductNum"  modal='true' closed='true' class='easyui-dialog' style='width:340px;height:330px'  title="产生代码">
 <table>
  <tr>
   <td>当前值</td>
   <td><s:textfield id="currentValue" theme="simple" value="%{#request.lgpAutoNum.currentValue}" cssStyle="width:150px" readonly="true"/></td>
  </tr>
  <tr>
   <td>增量</td>
   <td><s:textfield id="increase" theme="simple" value="%{#request.lgpAutoNum.increase}" cssStyle="width:150px"/></td>
  </tr>
  <tr>
   <td>最大值</td>
   <td><s:textfield id="max" theme="simple" value="%{#request.lgpAutoNum.max}"  cssStyle="width:150px"/></td>
  </tr>
  <tr>
   <td>种类</td>
   <td><s:textfield id="category" theme="simple" value="%{#request.lgpAutoNum.category}" cssStyle="width:150px" readonly="true"/> </td>
   
  </tr>
  <tr>
   <td>部门名称</td>
   <td><s:select list="#request.departList" id="departId" name="departId" theme="simple" cssStyle="width:150px" listKey="deptCode" listValue="deptName" value="1"></s:select></td>
  </tr>
  <tr>
   <td><input type="button" value="确定" onclick="confim()"/></td>
   <td><input type="button" value="取消"/></td>
  </tr>
 </table>
</div>

其中 modal='true' closed=“true”属性设置div的初始状态为隐藏,在div中初始化表单元素的value值为后台的数据

3、点击文本框时触发弹出div的函数

<s:textfield id="productNum" name="productNum" value="%{model.productNum}" cssClass="required" theme="simple" cssStyle="width:150px" readonly="true" onclick="generateNum()"></s:textfield>

4、js函数如下

function generateNum(){
   $j('#generateProductNum').dialog('open');
 }

在框架中存在jquery和prototype的冲突,为解决冲突问题必须采用

var  $j= jQuery.noConflict();

将$j符合作为jquery的标志符合。且var  $j= jQuery.noConflict();必须紧跟<script>之后,即在在开始执行script的时候先执行冲突函数,这样后续的prototype中的冲突就可以解决。即应用于所有js代码

5、点击div的确定按钮后执行的方法(将用户自定义的代码产生格式赋值到form表单中对应的文本域中 ,同时关闭弹出的div)

function confim(){
  var now=new Date();
  var departCode=document.getElementById('departId').value.toUpperCase();
  //var departCode=document.getElementById('departId').options[document.getElementById('departId').selectedIndex].text.toUpperCase();
  var currentValue=document.getElementById('currentValue').value;
  var increase=document.getElementById('increase').value;
  var valueNum=parseInt(currentValue)+parseInt(increase);
  
  if(valueNum/100<1){
   if(valueNum/10<1){
    valueNum="00"+valueNum;
   }else{
    valueNum="0"+valueNum;
   }
  }
  var productNum=departCode+now.getFullYear()+valueNum;
  document.getElementById('productNum').value=productNum;
  $j('#generateProductNum').dialog('close');
  
  }

6、当点击jsp页面上的提交按钮时将最终数据提交到后台,但是一定要同时修改代码产生规则表的数据使用ajax实现

function updateNum(){
   var currentValue=document.getElementById('currentValue').value;
   var increase=document.getElementById('increase').value;
   var url="/product/LgpAutoNum_update.action?increase="+increase+"&_t="+new Date().getTime();
   var myAjax=new Ajax.Request(
    url,
     {
         method:'get',
         setRequestHeader:{"If-Modified-Since":"0"},
         setRequestHeader:{"Cache-Control":"no-cache"},
          onComplete:afterNum
         
       }
    
   );
  
  }
  function afterNum(originalRequst){
   var result=originalRequst.responseText;
   if(result.length<0){
    alert("编号不符合规范");
   }
  
  }

使用ajax时如果多次添加产品记录,就会多次修改代码生成规则表的记录,这就需要使用ajax重复提交到相同的url,由于ajax的异步性在浏览器中多次提交时只执行一次并获得response中数据,这样就会在产品中产生相同的产品代码。

jsp中添加弹窗口并且实现向后台双向传递数据的更多相关文章

  1. JSP中添加弹出框

    JSP中添加弹出框 %> <script language="javascript" type="text/javascript"> aler ...

  2. 探究Spring Boot中的接收参数问题与客户端发送请求传递数据

    结合此篇参考Spring框架学习笔记(9)--API接口设计相关知识及具体编码实现 在使用Spring Boot进行接收参数的时候,发现了许多问题,之前一直都很忙,最近才稍微有空研究一下此问题. 网上 ...

  3. jsp中添加过滤器,实现校验用户身份

    我现在需要实现一个功能,就是用户登录前不允许访问系统,我使用的是jsp的过滤器来实现的. 先把filter过滤器的代码粘出来: package com.day8.filter; import java ...

  4. 【转载】在C#中主线程和子线程如何实现互相传递数据

    引用:https://blog.csdn.net/shuaihj/article/details/41316731 一.不带参数创建Thread using System; using System. ...

  5. JSP中使用JDBC连接MySQL数据库的详细步骤

    1,首先在自己新建的项目文本框中输入Web Project的名称,然后单击下一步. 2,继续单击下一步 3,把Generate web.xml deployment descriptor复选框勾上. ...

  6. JSP中的内置对象和Struts中的Web资源的详解

    JSP中的内置对象有如下几种: request :继承于HttpServletRequest, HttpServletRequest继承ServletRequest, 获得的Request对象的方法: ...

  7. JSP中页面向Action传递参数的几种方式

    <form name="ThisForm" method="POST" action="index.jsp"> form是表单, ...

  8. 对类HelloWorld程序中添加一个MessageBox弹窗

    对类HelloWorld程序中添加一个MessageBox弹窗 分析: 任一程序运行的时候都会加载kernel32.dll的,但MessageBoxA()这个API却是在user32.dll中的.所以 ...

  9. jsp实现仿QQ空间新建多个相册名称,向相册中添加照片

    工具:Eclipse,Oracle,smartupload.jar:语言:jsp,Java:数据存储:Oracle. 实现功能介绍: 主要是新建相册,可以建多个相册,在相册中添加多张照片,删除照片,删 ...

随机推荐

  1. USACO 1.4 ariprog 解题报告

    这是继虫洞之后又让我为难的一个 剪枝题目,无论如何,做的再快,也只能过6个点,最后三个点也TLE.后来参考了一下标答,大概思路是这样的. 朴素算法就不多说了,枚举a,b然后判断就行,网上说这样优化到位 ...

  2. error LNK2019: 无法解析的外部符号 "public:

    错误 1 error LNK2019: 无法解析的外部符号 "public: __thiscall test::test(void)" (??0test@@QAE@XZ),该符号在 ...

  3. vs2012配置opencv及简单测试

    为visual studio2012搭建openCV平台,实现打开图片. 实现步骤: 1.1.配置环境变量 基于win7操作系统的环境配置步骤: 1.1.1 计算机—>属性—>更改设置—& ...

  4. JS判断邮箱格式

    function check(){    var strText=$("#email").val();    var strReg=/^\w+((-\w+)|(\.\w+))*\@ ...

  5. AngularJS入门基础PPT(附下载链接)

    学习了Angularjs有段时间,自己写了一个PPT,个人认为总结的非常全面,对于入门基础够了. 大致模块有:Angularjs简单介绍,Angularjs特性,hello world,Control ...

  6. php composer使用

    Composer-PHP中用来管理依赖(dependency) 定义 composer是PHP中用来管理依赖(dependency)关系的工具.你可以在自己的项目中声明所依赖的外部工具库(librar ...

  7. placeholder在不同浏览器下的表现及兼容方法 placeholder兼容

    1.什么是placeholder?    placeholder是html5新增的一个属性,当input或者textarea设置了该属性后,该值的内容将作为灰字提示显示在文本框中,当文本框获得焦点(或 ...

  8. 实测Eclipse连接小米2S调试问题

    小米2S手机在Eclipse真机调试时,设备选择列表无法显示手机,DDMS也连接不上设备,解决步骤: 1.打开手机设置中开发者选项 - USB调试开启: 2.保证小米2S手机Windows下设备驱动已 ...

  9. 4.1. 如何在Windows环境下开发Python

    4.1. 如何在Windows环境下开发Python 4.1. 如何在Windows环境下开发Python 4.1.1. Python的最原始的开发方式是什么样的 4.1.1.1. 找个文本编辑器,新 ...

  10. thinkphp中的where()方法

    where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM的重要组成部分和亮点所在,可以完成包括普通查询.表达式查询.快捷查询.区间查询.组合查询在内的查询操作.where方法 ...