工作笔记:ajax json 同一jsp页面中,把java变量赋给js变量,如果java变量字符串符合json格式,则赋给js变量时,js变量会自动的变为json对象

本文深入探讨了如何在JSP页面中通过JavaScript实现与服务器端交互,详细介绍了页面语言与脚本语言之间的数据传递机制,包括字符串与对象的正确语法使用,以及如何在客户端正确解析接收到的数据。文章还提供了实际案例,帮助读者理解并实践这些概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
 String s="{source_type_code:'2',source_type_name:'电话赠险成功'}";
%>
<script type="text/javascript" src="jquery-1.7.1.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 bindData();
});
function bindData(){
 var a="<%=s%>";//必须是双引号,不能是单引号
 alert(a);
}
</script>
------------------------------------------------输出:{source_type_code:'2',source_type_name:'电话赠险成功'},加了双引号传的是字符串
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
 String s="{source_type_code:'2',source_type_name:'电话赠险成功'}";
%>
<script type="text/javascript" src="jquery-1.7.1.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 bindData();
});
function bindData(){
 var a=<%=s%>;
 alert(a);
}
</script>
------------------------------------------------输出:object Object,不加双引号传的是对象
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
 String s="{source_type_code:'2',source_type_name:'电话赠险成功'}x";
%>
<script type="text/javascript" src="jquery-1.7.1.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 bindData();
});
function bindData(){
 var a="<%=s%>";
 alert(a);
}
</script>

------------------------------------------------输出{source_type_code:'2',source_type_name:'电话赠险成功'}x,加了双引号传的是字符串
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
 String s="{source_type_code:'2',source_type_name:'电话赠险成功'}x";
%>
<script type="text/javascript" src="jquery-1.7.1.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 bindData();
});
function bindData(){
 var a=<%=s%>;
 alert(a);
}
</script>
----------------------------------------不输出,会报错,如果不加双引号,应该输出对象的,但s串不是符合格式的字符串,必须符合json格式的字符串才能转化为对象传给js变量
java代码片段在服务器端运行,运行生成的结果放在生成的静态页面中再发送到用户浏览器端,浏览器再运行js代码,比如:
<script   language= "javascript ">
      var a= "<%out.print( "hello ");%>";
</script>
实际上到了用户浏览器端就会执行:
<script   language= "javascript ">
      var   a= "hello ";
</script>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值