Jquery框架下Ajax与PHP数据交换
一、前台传递字符串变量,后台返回字符串变量(非json格式)
Javascript代码:
这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对返回
的字符串使用unescape()函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决
汉字乱码问题的方式如下:
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data="前台变量"<span style="color: #000000;">; </span><span style="color: #008080;"> 3</span> my_data=escape(my_data)+"";<span style="color: #008000;">//</span><span style="color: #008000;">编码,防止汉字乱码</span> <span style="color: #008080;"> 4</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;"> 5</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;"> 6</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;"> 7</span> <span style="color: #000000;"> data:{trans_data:my_data}, </span><span style="color: #008080;"> 8</span> <span style="color: #008000;">//</span><span style="color: #008000;">dataType: "json",</span> <span style="color: #008080;"> 9</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">10</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">11</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">12</span> success: <span style="color: #0000ff;">function</span>(data,status){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">13</span> alert(unescape(data));<span style="color: #008000;">//</span><span style="color: #008000;">解码,显示汉字</span> <span style="color: #008080;">14</span> <span style="color: #000000;"> } </span><span style="color: #008080;">15</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">16</span> <span style="color: #008080;">17</span> });
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码</span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">4</span> <span style="color: #0000ff;">echo</span> <span style="color: #800080;">$backValue</span>."+后台返回"<span style="color: #000000;">; </span><span style="color: #008080;">5</span> ?>
显示效果如下图所示:
二、前台传递多个一维数组,后台返回字符串变量(非json格式)
Javascript代码:
在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 5</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> <span style="color: #008080;"> 8</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">10</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">13</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">14</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">15</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1}, </span><span style="color: #008080;">16</span> <span style="color: #008000;">//</span><span style="color: #008000;">dataType: "json",</span> <span style="color: #008080;">17</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">18</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">19</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">20</span> success: <span style="color: #0000ff;">function</span>(data,status){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">21</span> alert(data); <span style="color: #008080;">22</span> <span style="color: #000000;"> } </span><span style="color: #008080;">23</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">24</span> <span style="color: #008080;">25</span> });
PHP代码:
<span style="color: #008080;"> 1</span> <span style="color: #000000;">php </span><span style="color: #008080;"> 2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span><span style="color: #008080;"> 3</span> <span style="color: #008080;"> 4</span> <span style="color: #008000;"> //读取第一个数组</span> <span style="color: #008080;"> 5</span> <span style="color: #800080;">$backValue</span>="trans_data:"<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> <span style="color: #800080;">$trans</span>=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;"> 7</span> <span style="color: #0000ff;">foreach</span>(<span style="color: #800080;">$trans</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$value</span><span style="color: #000000;">) </span><span style="color: #008080;"> 8</span> <span style="color: #000000;"> { </span><span style="color: #008080;"> 9</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." ".<span style="color: #800080;">$value</span><span style="color: #000000;">; </span><span style="color: #008080;">10</span> <span style="color: #000000;"> } </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #008000;">//</span><span style="color: #008000;">读取第二个数组</span> <span style="color: #008080;">13</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." , trans_data1:"<span style="color: #000000;">; </span><span style="color: #008080;">14</span> <span style="color: #800080;">$trans</span>=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">15</span> <span style="color: #0000ff;">foreach</span>(<span style="color: #800080;">$trans</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$value</span><span style="color: #000000;">) </span><span style="color: #008080;">16</span> <span style="color: #000000;"> { </span><span style="color: #008080;">17</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." ".<span style="color: #800080;">$value</span><span style="color: #000000;">; </span><span style="color: #008080;">18</span> <span style="color: #000000;"> } </span><span style="color: #008080;">19</span> <span style="color: #0000ff;">echo</span> <span style="color: #800080;">$backValue</span><span style="color: #000000;">; </span><span style="color: #008080;">20</span> ?>
显示效果如下图:
三、前台传递多个一维数组,后台返回二维数组(json格式)
Javascript代码:
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 5</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> <span style="color: #008080;"> 8</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">10</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">13</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">14</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">15</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1}, </span><span style="color: #008080;">16</span> dataType: "json"<span style="color: #000000;">, </span><span style="color: #008080;">17</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">18</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">19</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">20</span> success: <span style="color: #0000ff;">function</span>(data){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">21</span> <span style="color: #0000ff;">var</span> back=""<span style="color: #000000;">; </span><span style="color: #008080;">22</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> i=0;i){ <span style="color: #008080;">23</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> j=0;j<data style="color: #000000;">){ <span style="color: #008080;">24</span> back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "<span style="color: #000000;">; </span><span style="color: #008080;">25</span> <span style="color: #000000;"> } </span><span style="color: #008080;">26</span> back+="\n"<span style="color: #000000;">; </span><span style="color: #008080;">27</span> <span style="color: #000000;"> } </span><span style="color: #008080;">28</span> <span style="color: #000000;"> alert(back); </span><span style="color: #008080;">29</span> <span style="color: #000000;"> } </span><span style="color: #008080;">30</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">31</span> <span style="color: #008080;">32</span> });</data>
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008080;">4</span> <span style="color: #800080;">$backValue</span>[0]=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">5</span> <span style="color: #800080;">$backValue</span>[1]=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">6</span> <span style="color: #008080;">7</span> <span style="color: #0000ff;">echo</span> json_encode(<span style="color: #800080;">$backValue</span><span style="color: #000000;">); </span><span style="color: #008080;">8</span> ?>
显示效果如下图:
四、前台传递一维数组和二维数组,后台返回二维数组(json格式)
Javascript代码:
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> <span style="color: #0000ff;">var</span> my_data2=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 5</span> <span style="color: #008080;"> 6</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 8</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> <span style="color: #008080;">10</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;">11</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">12</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">13</span> <span style="color: #008080;">14</span> my_data2[0]=<span style="color: #000000;">my_data; </span><span style="color: #008080;">15</span> my_data2[1]=<span style="color: #000000;">my_data1; </span><span style="color: #008080;">16</span> <span style="color: #008080;">17</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">18</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">19</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">20</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2}, </span><span style="color: #008080;">21</span> dataType: "json"<span style="color: #000000;">, </span><span style="color: #008080;">22</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">23</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">24</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">25</span> success: <span style="color: #0000ff;">function</span>(data){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">26</span> <span style="color: #0000ff;">var</span> back=""<span style="color: #000000;">; </span><span style="color: #008080;">27</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> i=0;i){ <span style="color: #008080;">28</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> j=0;j<data style="color: #000000;">){ <span style="color: #008080;">29</span> back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "<span style="color: #000000;">; </span><span style="color: #008080;">30</span> <span style="color: #000000;"> } </span><span style="color: #008080;">31</span> back+="\n"<span style="color: #000000;">; </span><span style="color: #008080;">32</span> <span style="color: #000000;"> } </span><span style="color: #008080;">33</span> <span style="color: #000000;"> alert(back); </span><span style="color: #008080;">34</span> <span style="color: #000000;"> } </span><span style="color: #008080;">35</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">36</span> <span style="color: #008080;">37</span> });</data>
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008080;">4</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$_POST</span>['trans_data2'<span style="color: #000000;">]; </span><span style="color: #008080;">5</span> <span style="color: #800080;">$backValue</span>[2]=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">6</span> <span style="color: #800080;">$backValue</span>[3]=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">7</span> <span style="color: #008080;">8</span> <span style="color: #0000ff;">echo</span> json_encode(<span style="color: #800080;">$backValue</span><span style="color: #000000;">); </span><span style="color: #008080;">9</span> ?>
显示效果如下图:

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

IIS和PHP可以兼容,通过FastCGI实现。1.IIS通过配置文件将.php文件请求转发给FastCGI模块。2.FastCGI模块启动PHP进程处理请求,提高性能和稳定性。3.实际应用中需注意配置细节、错误调试和性能优化。

C 的未来将专注于并行计算、安全性、模块化和AI/机器学习领域:1)并行计算将通过协程等特性得到增强;2)安全性将通过更严格的类型检查和内存管理机制提升;3)模块化将简化代码组织和编译;4)AI和机器学习将促使C 适应新需求,如数值计算和GPU编程支持。

1)c relevantduetoItsAverity and效率和效果临界。2)theLanguageIsconTinuellyUped,withc 20introducingFeaturesFeaturesLikeTuresLikeSlikeModeLeslikeMeSandIntIneStoImproutiMimproutimprouteverusabilityandperformance.3)

AI可以帮助优化Composer的使用,具体方法包括:1.依赖管理优化:AI分析依赖关系,建议最佳版本组合,减少冲突。2.自动化代码生成:AI生成符合最佳实践的composer.json文件。3.代码质量提升:AI检测潜在问题,提供优化建议,提高代码质量。这些方法通过机器学习和自然语言处理技术实现,帮助开发者提高效率和代码质量。

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。
