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

<%@ 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>

相关文章

JS原生Ajax操作(XMLHttpRequest) GET请求 POST请求 兼容性问题 利用iframe模拟ajax 实现表单提交的返回...
AJAX 每日更新前端基础,如果觉得不错,点个star吧 &#128515; https://github.com/WindrunnerMax/E...
踩坑Axios提交form表单几种格式 前后端分离的开发前后端, 前端使用的vue,后端的安全模块使用的SpringSe...
很早就听闻ajax的名声,但是却一直不知道怎么用,今天自己捣鼓了一下,竟然会用了,哈哈哈哈。 为了防止...
需要在服务器上进行哈 jquery的ajax方法: // jquery请求 $.ajax({ url: &quot;./server/slider.js...
Ajax函数封装ajax.js // Get / Post // 参数 get post // 是否异步 // 如何处理响应数据 // URL // var...