我们都知道 jsp页面中获取java后端的数组可以有很多方法。
比如JSP的表达式<%= %>或者EL表达式${}。
或者C标签,S标签等。
可参考:
JSP标准标签库-c标签等
s标签显示后台数据的基本用法以及iterator遍历用法
但js中是不能直接使用java后端传值的数组的。
有两个解决方法:
1.ajax请求返回数组,这种方式返回的数组是直接能使用的。这里就不详说了。
2.把java的数组转换成 js数组。 本章主要讲解这种方式。
el表达式生效的时候javascript代码还全都是文本 等javascript生效的时候早就没了el表达式了。
js是客户端执行,EL是在服务端执行,而服务端比客户端先执行,所以你不能用js来改变已经执行的el表达式的值
但是却可以用el来给js初始化传值。
也就是不能再在js的逻辑代码中再去获取EL表达式,只能在js的逻辑代码中把EL表达式的输出 当成文本。
如果JS脚本不是在JSP页面里而是在单独的JS文件里,这时用EL初始传值是不起作用的,但你可以通过window.onload()来得到EL的值再传送给JS文件里的方法进行变量初始化
所以我们发现在jsp中生效的 ${strs.length}是不生效的。
只能通过fn函数
页面引入<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>
${fn:length(strs)} 可在js中获取java数组的长度。
把java数组转换成js数组的原理是创建一个js数组然后把java数组中的值取出放进去。
我们现在有一个costList数组,格式是String[]
现在新建一个 list1的js数组Array 来获取 costList数组的值。
有如下几种方法:
var list1 = new Array(
5.0,3.0,4.0,5.0,4.0,4.0,5.0,4.0,5.0
)
构造出这样的js代码就行。
function initSit() { var list1 = new Array( <c:forEach items="${costList}" begin="0" end="0" var="cost">${cost}</c:forEach> <c:forEach items="${costList}" begin="1" var="cost">,${cost}</c:forEach> ) //这里是属于js的部分 var i=0; for(;i<list1.length ;i++) { alert(list1[i]); } } initSit();
function initSit() { var list1 = new Array( <% String[] costList = (String[])request.getAttribute("costList"); //使用java脚本来输出数字 //数组是costList[0],List则是costList.get(0) out.print(costList[0]); //这里这么写很重要...只有这样才能个js的 Array对象正确赋值 for(int i=1; i<costList.length; i++) { out.print(","); out.print(costList[i]); } //java脚本部分结束 %> ) //这里是属于js的部分 var i=0; for(;i<list1.length ;i++) { alert(list1[i]); } } initSit();
function initSit() { <% String[] str = (String[])request.getAttribute("costList"); %> var list1= new Array(<%=str.length)%>); <% for(int i=0;i<str.length;i++) { %> list1= [<%=i%>] =<%=str[i]%>; <%}%> var i=0; for(;i<list1.length ;i++) { alert(list1[i]); } }initSit();