gpt4 book ai didi

javascript - 如何使用jsp将mysql字符串存储在javascript变量中

转载 作者:行者123 更新时间:2023-11-29 12:12:02 24 4
gpt4 key购买 nike

我想将 mysql 字符串存储在 JavaScript 数组变量中。我在服务器端使用jsp。

我尝试了三种方法。这三个都不起作用。需要一些帮助。

尝试 1:

<script>
var name = [];
<%
st=con.prepareStatement("select name from company");
rs=st.executeQuery();
while(rs.next()){
String s = rs.getString(1);
%>
name.push(<%=s%>);
<%
}
%>
</script>
<小时/>

尝试 2:

<script>
var name = [];
<%
st=con.prepareStatement("select name from company");
rs=st.executeQuery();
while(rs.next()){
%>
name.push(<%=rs.getString(1)%>);
<%
}
%>
</script>
<小时/>

尝试 3:

<script>
var name = [];
<%
st=con.prepareStatement("select name from company");
rs=st.executeQuery();
while(rs.next()){
%>
name.push(<%out.print(rs.getString(1));%>);
<%
}
%>
</script>
<小时/>

所有三次尝试在处理后都显示相同的结果和错误。

解释代码:

<script>
var name = [];
name.push(tcs);
name.push(wipro);
</script>

错误:

ReferenceError: tcs is not defined
<小时/>

最佳答案

您应该添加"在你的字符串周围你也应该用javascript对其进行编码(我认为apache有一个库可以为你做到这一点):

<script>
var name = [];
<%
st=con.prepareStatement("select name from company");
rs=st.executeQuery();
while(rs.next()){
String s = StringEscapeUtils.escapeJavaScript(rs.getString(1));
%>
name.push("<%= s %>");
<%
}
%>
</script>

尝试使用此 Apache 库根据 javascript 规则转义 java 字符串:StringEscapeUtils

Javascript 正在尝试解释 name.push(tcs); tcs作为变量,在本例中 tcs尚未声明或初始化,它是未定义的。相反,您希望 javascript 解释 tcs作为字符串,因此您需要在其周围加上引号 "tcs"或者在你的情况下"<%= s %>" .

关于javascript - 如何使用jsp将mysql字符串存储在javascript变量中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30489735/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com