遇到的问题----js获取java的数组



我们都知道 jsp页面中获取java后端的数组可以有很多方法。


比如JSP的表达式<%= %>或者EL表达式${}。


或者C标签,S标签等。 


可参考:

JSP标准标签库-c标签等

s标签显示后台数据的基本用法以及iterator遍历用法



但js中是不能直接使用java后端传值的数组的。


有两个解决方法:

1.ajax请求返回数组,这种方式返回的数组是直接能使用的。这里就不详说了。

2.把java的数组转换成 js数组。  本章主要讲解这种方式。



JS中遍历一个EL表达式的集合为空原因

el表达式生效的时候javascript代码还全都是文本 等javascript生效的时候早就没了el表达式了。


js是客户端执行,EL是在服务端执行,而服务端比客户端先执行,所以你不能用js来改变已经执行的el表达式的值

但是却可以用el来给js初始化传值。

也就是不能再在js的逻辑代码中再去获取EL表达式,只能在js的逻辑代码中把EL表达式的输出 当成文本。


如果JS脚本不是在JSP页面里而是在单独的JS文件里,这时用EL初始传值是不起作用的,但你可以通过window.onload()来得到EL的值再传送给JS文件里的方法进行变量初始化



js获取java数组的长度

所以我们发现在jsp中生效的 ${strs.length}是不生效的。

只能通过fn函数 

页面引入<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>

${fn:length(strs)} 可在js中获取java数组的长度。




把java的数组转换成 js数组

把java数组转换成js数组的原理是创建一个js数组然后把java数组中的值取出放进去。

我们现在有一个costList数组,格式是String[]

现在新建一个 list1的js数组Array 来获取  costList数组的值。


有如下几种方法:

使用c标签EL表达式在创建js数组时拼接

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();



使用java脚本在创建js数组时拼接

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();




先创建js数组再java脚本循环赋值

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();

 
 








你可能感兴趣的:(遇到的问题----js获取java的数组)