- 浏览: 1990916 次
- 性别:
- 来自: 哈尔滨
-
文章分类
- 全部博客 (188)
- java基础 (22)
- 经验+注意 (39)
- Oracle (34)
- javaScript (28)
- jquery (24)
- iBatIS (11)
- hibernate (8)
- struts1.x (1)
- spring (1)
- SVN (1)
- myeclipse (12)
- jbmp工作流 (1)
- 其他 (22)
- 杂谈 (4)
- struts2 (5)
- css (4)
- 正则表达式 (2)
- jstl标签 (4)
- Java Tree (2)
- Jboss (1)
- json (1)
- HttpURLConnection (1)
- Apache commons工具包 (1)
- groovy+grails (2)
最新评论
-
q2425533:
Java字符串倒序输出 + 数组的排序 -
变脸小伙:
今天也跟着学习了,用到了
struts2拦截器 获得请求方法名+获得请求参数 -
tuspark:
讲解的很不错。URLConnection类的内容也可以看这篇文 ...
HttpURLConnection详解 -
wolf746773350:
...
window.location.href/replace/reload()--页面跳转+替换+刷新 -
wolf746773350:
[/flash]
window.location.href/replace/reload()--页面跳转+替换+刷新
eval()函数,曾经自己并不觉得怎么样,但是项目中遇到一个需求,被迫使用,感觉确实很强大,记下来,忘了了看看!
需求: 1) 省内价格可用精确到地市(即,区号),省外价格只精确到省。(产品表中的产品集合将精确到地市,即一万多产品;非本省操作时,将只显示省名称,实际操作地市产品)。
2) 产品查询:(查询条件)
a) 地区(省内选择地市,省外选择省份)
b) 面值
c) 运营商
综上:1.jsp页面需要一个二级联动<select>,选择省内时查出当前工号对应省份的所有
城市,例如:省内(黑龙江)-->查出哈尔滨、齐齐哈尔、大庆等。
2.选择省外,查出T_AREA表中所有的省份,例如:黑龙江、辽宁、河南等。
一、ServiceImpl中方法
/* 查询所有省号、所有省份名称--去掉重复的,此方法hibernate返回一个Object数组,对distinct 封装了 * @date 2011-5-21 下午04:31:26 */ @Override public List<TArea> getProvinceAndCodeList() { String hql = "select distinct t.provinceCode,t.province from TArea t"; List<TArea> list = queryByHql(hql); return list; } /* 根据区号,查询当前区号对应省内的所有市 集合 * @date 2011-5-21 下午04:57:00 */ @Override public List<TArea> getProvinceListByAreaCode(String areaCode) { String sql = ""; if(null != areaCode && !"".equals(areaCode)){ sql = "select * from t_area t where t.province_code=" + "(select t1.province_code from t_area t1 where t1.area_code='"+areaCode+"')"; } List<TArea> list = queryBySql(sql); return list; }
二、struts2的Action两个方法中查询出
/** * 获得当前工号省内的所有--选择的省内 * @author mengxianjun * @date 2011-5-23 上午09:28:14 */ public void getAllCity() { try { String area_code = ConfigCtrl.getConfigValue("area_code");//配置表,获得默认区号 tAreaList = areaService.getProvinceListByAreaCode(area_code);//当前工号所在省的所有市集合 this.getResponse().setCharacterEncoding("UTF-8"); PrintWriter out = this.getResponse().getWriter(); JSONArray myjsonObj = JSONArray.fromObject(tAreaList); out.println(myjsonObj.toString()); out.flush(); out.close(); } catch( Exception e ) { log.error("PriceStrategyAction's method getAllCity ",e); } } /** * 获得所有省--选择的省外 * @author mengxianjun * @date 2011-5-23 上午09:28:14 */ public void getAllProvince() { try { allProvinceList = areaService.getProvinceAndCodeList();//所有省集合 this.getResponse().setCharacterEncoding("UTF-8"); PrintWriter out = this.getResponse().getWriter(); JSONArray myjsonObj = JSONArray.fromObject(allProvinceList); out.println(myjsonObj.toString()); out.flush(); out.close(); } catch( Exception e ) { log.error("PriceStrategyAction's method getAllProvince ",e); } }
三、jsp页面给<select>添加onchange事件,对应省内、省外变换<option>
<script type="text/javascript"> function getAllCityOrProvince() { if( $("#Area_a").val()=='no' ) { $("#Area_b").empty();//清空列表 $("<option></option>").val("no").text(" ").appendTo($("#Area_b")); } /*省内*/ if( $("#Area_a").val()=='nei' ) { $("#Area_b").empty();//清空列表 $.post("priceStrategy_getAllCity",'',function(data){ $.each(eval(data),function(i){ $("<option></option>").val(eval(data)[i].areaCode).text(eval(data)[i].city).appendTo($("#Area_b")); }); }); } /*省外*/ if( $("#Area_a").val()=='wai' ) { $("#Area_b").empty();//清空列表 $.post("priceStrategy_getAllProvince","",function(data){ //alert(data); $.each(eval(data),function(i){ $("<option></option>").val(eval(eval(data)[i])[0]).text(eval(eval(data)[i])[1]).appendTo($("#Area_b")); }); //第二种方法,纯js循环输出 //alert(data); //alert(eval(data).length); /*for( var i=0; i<eval(data).length; i++ ) { var obj1 = eval(eval(data)[i])[0]; var obj2 = eval(eval(data)[i])[1]; $("<option></option>").val(obj1).text(obj2).appendTo($("#Area_b")); }*/ }); } } </script>
四、jsp页面,表单内容
<s:form id="form1" action="" target="main"> <table border=1 width="100%"> <tr> <td colspan="3">查询操作</td> </tr> <tr> <td> 地区: </td> <td> <select id="Area_a" name="Area_a" size="1" onchange="getAllCityOrProvince()"> <option value="no">==请选择==</option> <option value="nei">省内</option> <option value="wai">省外</option> </select> <select id="Area_b" name="Area_b" size="1"> <option value="no"> </option> </select> </td> <td><span id="textArea"></span></td> </tr> <tr> <td> 面值: </td> <td> <input type="checkbox" id="selectALLMoney" onclick="checkAll(this,'money')"/>全选 <input type="checkbox" name="money" value="1"/>1 <input type="checkbox" name="money" value="3"/>3 <input type="checkbox" name="money" value="5"/>5 <input type="checkbox" name="money" value="10"/>10 <input type="checkbox" name="money" value="20"/>20 <input type="checkbox" name="money" value="30"/>30 <input type="checkbox" name="money" value="50"/>50 <br> <input type="checkbox" name="money" value="100"/>100 <input type="checkbox" name="money" value="200"/>200 <input type="checkbox" name="money" value="300"/>300 <input type="checkbox" name="money" value="500"/>500 <input type="checkbox" name="money" value="1000"/>1000 </td> <td><span id="textMoney"></span></td> </tr> <tr> <td> 运营商: </td> <td> <select id="operatorsCode" name="operatorsCode" size="1"> <option value="all">全部</option> <option value="40">移动</option> <option value="41">联通</option> <option value="42">电信</option> </select> </td> <td> </td> </tr> <tr> <td> </td> <td> <input type="button" value=" 查询 " onclick="queryPrice()"/> <input type="button" value=" 重置 " onclick="resetQueryPrice()"/> </td> <td> </td> </tr> </table> <c:choose> <c:when test="${ pageHelper != null }"> <table border=1 width="100%"> <tr> <td colspan="3">批量操作</td> </tr> <tr> <td>价格:</td> <td> <input type="radio" id="pricesMarks" name="updateType" value="prices" checked="checked" onclick="pricesMarksOrRatioMarks()"><label for="pricesMarks">价格</label> <input type="radio" id="ratioMarks" name="updateType" value="ratio" onclick="pricesMarksOrRatioMarks()"><label for="ratioMarks">比率 </label> <input type="text" id="price" name="price"> </td> <td><span id="textPrice"></span></td> </tr> <tr> <td colspan="2"> <input type="button" id="batchUpdate" value="批量修改" onclick="batchUpdateMethod()"> <input type="button" id="allUpdate" value="全部修改" onclick="allUpdateMethod()"> </td> <td><span id="textBatchUpdate"></span></td> </tr> </table> <table border=1 width="100%"> <tr> <td> <display:table id="myList" name="pageHelper" requestURI="priceStrategy_querAllPriceStrategy" sort="list" size="count"> <display:column title="<input type='checkbox' id='selectALL' onclick=\"checkAll(this,'checkboxProductTypeNum')\"/\>"> <input type="checkbox" name="checkboxProductTypeNum" value="${ myList.typeNum }"/> <input type="hidden" name="hiddenTypeNum" value="${ myList.typeNum }"/> </display:column> <display:column property="typeName" title="价格策略名称"/> <display:column property="createDate" title="创建时间" /> <display:column title="操作"> <a href="priceStrategy_openUpdatePriceStrategy?typeNum=${ myList.typeNum }" target="main">修改策略</a>|| <a href="priceStrategy_showDetailPriceStrategy?typeNum=${ myList.typeNum }" target="main">查看详情</a> </display:column> </display:table> </td> </tr> </table> </c:when> <c:otherwise> </c:otherwise> </c:choose> </s:form>
发表评论
-
即时搜索的input和propertychange方法
2018-01-16 16:59 1756做搜索功能的时候,经常遇到输入框检查的需求,最常见的是即时搜 ... -
jQuery Ajax 实例 ($.ajax、$.post、$.get)
2012-02-09 10:43 301012Jquery在异步提交方面封装的很好,直接用AJAX非常麻烦, ... -
checkbox加onClick事件,ajax异步请求后台,$.ajax
2012-02-08 17:02 6822XXX平台要实现一个功能,公告弹出页面上使用复选框设置不再通知 ... -
jquery显示、隐藏div的方法
2012-01-16 13:27 23600###例子 $("#top_notice" ... -
jquery 二级联动
2012-01-09 14:35 1281jquery 二级联动 -
jquery.cookies.2.2.0+半小时后自动跳转至sessionView.jsp提示session过期
2011-10-15 13:15 2838详细方法说明参见:http://code.google.com ... -
Jquery FrameSet设置换肤
2011-09-30 15:25 3233使用Jquery给<FrameSet>换肤, ... -
<input type="text">文本框选中输入的值
2011-09-23 17:39 2417#1.js校验中,可以这样用,jquery同样支持.selec ... -
Jquery AJAX|Jquery .serialize() --序列表表格内容为字符串,用于 Ajax 请求+序列化表单拼接Url字符串
2011-09-21 12:00 8983Jquery AJAX操作时,传data一般分为两种:1.合成 ... -
jQuery ajax 同步 异步
2011-08-16 18:01 2319$.ajax({ url:'<%=request ... -
业务密码校验,AJAX异步校验时间有诧异
2011-08-15 17:53 1745在项目中我使用了AJAX异步校验,来校验业务密码是否正确,本地 ... -
jquery得到div的id值
2011-07-30 17:08 6889<div id="product_shift_ ... -
jquery操作select
2011-07-23 16:28 2586//得到select项的个数 jQuery.fn. ... -
jquery 限制文本框只能输入数字
2011-07-16 15:55 37814jquery 限制文本框只能输入数字 转自:http: ... -
jQuery 效果 - slideToggle() 方法
2011-07-07 17:36 1772实例 通过使用滑动效果,在显示和隐藏状态之间切换 <p ... -
扩展Jquery,自定义函数
2011-06-15 17:07 2386##我们常常需要自定义一些函数,供全局、所有人使用,做法如下: ... -
js+jquery表单验证--自己总结
2011-06-02 16:22 2074###js+jquery验证表单,自己总结的。定义判断的变量t ... -
jquery操作input、select、checkbox、radio常用方法
2011-05-24 15:40 6859jQuery获取Select选择的Text和Value ... -
jQuery获取Select选中的Text和Value
2011-05-24 15:38 1392我在项目中这样使用: var checkText=$(&qu ... -
jquery的each()用法
2011-05-20 17:22 1480转自:http://www.stuhack.com/bianc ...
相关推荐
### JavaScript + XML 实现下拉二级联动菜单 #### 一、简单说明与功能特性 本文将详细介绍如何利用JavaScript和XML来构建一个具有二级联动功能的下拉菜单。此菜单的一个显著优势是它能够覆盖网页上的任何元素,...
### 使用jQuery、Ajax、JSP与Servlet实现二级级联菜单 #### 一、项目背景与技术栈概述 本文档将详细介绍如何使用jQuery、Ajax、JSP与Servlet来实现一个简单的二级级联菜单功能。该功能常见于许多Web应用程序中,如...
该项目实现了四级联动菜单的功能,可以方便地根据实际需求调整为三级或二级联动菜单。 #### 二、四级联动菜单原理 四级联动菜单是一种常见的前端交互设计模式,通过用户的下拉选择操作,动态更新后续级别的下拉选项...
在介绍ajax实现select三级联动效果的知识点之前,首先要了解什么是三级联动。三级联动是指在一个Web页面中,通过选择一个下拉列表选项,能够触发其他两个下拉列表选项的动态更新。通常这样的场景用于地理位置信息的...
- 第二个`<select>`元素的`name`属性为"ZY",选项的数据源是计算属性`selection`的结果。 2. **Vue实例**: - `el:'#test'`指定了Vue实例的作用域,即`id`为"test"的元素。 - `data`对象中定义了一个名为`YX`的...
这里我们关注的是如何利用AJAX实现三级联动的效果,即在一个下拉菜单中选择一项时,相关的第二级和第三级下拉菜单会根据选择自动更新其内容。这在如地区选择、产品分类等场景中非常常见。 首先,我们需要理解AJAX的...
在JavaScript和jQuery编程中,动态添加的HTML元素可能会导致与之相关的事件处理程序失效,这是因为JavaScript在页面加载时只...同时,确保正确处理Ajax异步请求和数据解析,以实现预期的功能,如本例中的二级联动选择。