PHP ajax实现数组返回

首先,我想要实这样一个功能,

当选择一个下拉框时,让其它三个文本框得到从服务器上返回的值!也就把返回的值,赋给那三个文本框!

我用的是jquery+php!! 由于我前台,后台,js,数据库采用的都是gb2312编码,所以,走了些弯路!

js代码:

$("#logname").change(function(){
        
        if($("#logname").val() != ""){
            $.ajax({
                url: "ajax.php?ac=kl_tjyj",
                type:‘POST‘,
                complete :function(){}, //請求完回調的函數,無論成功與失敗都會調用,在success後
                dataType: ‘json‘, //會把回傳的字符串自動轉換為json對象!
                data: {logname: $("#logname").val()},
                
                error: function() { alert(‘Ajax request 發生錯誤‘);},
                
                success: function(response) {
                    
                $("#yname").attr("value",response.yname);
                $(‘#zubie‘).val(response.zubie);
                $(‘#zhiwu‘).val(response.zhiwu);
                alert(‘添加成功!‘);
    
                }
           });
            
        }
    });

php代码如下:

if (get("ac") == ‘kl_tjyj‘) {

if(isset($_POST[‘logname‘])) {
        $queryString = post(‘logname‘);
        $queryString = iconv( ‘UTF-8‘, ‘gb2312‘ , $queryString);//解决传递过来的参数为中文乱码

if(strlen($queryString) >0) {

$sql = "select jj_truename,zhiwu,zubie from jj_ren where jjrenname=‘$queryString‘ limit 0,1";
            $result = $h->sql($sql);
            if(mysql_num_rows($result)) {
                while($row = mysql_fetch_array($result)){
                    $arr = array (‘yname‘=>iconv( ‘gb2312‘, ‘UTF-8‘ , $row[‘jj_truename‘]),‘zubie‘=>iconv(‘gb2312‘,‘UTF-8‘,$row[‘zubie‘]),‘zhiwu‘=>iconv(‘gb2312‘,‘UTF-8‘,$row[‘zhiwu‘]));
                }
                echo json_encode($arr);
            } else {
                echo ‘<script>alert("没有找到该人的");</script>‘;
            }
        } else {
            echo ‘<script>alert("提交的数据不能为空!");</script>‘;
        } 
    } else {
        echo ‘‘;
    }

}

附言:

JSON为何物?我就不重复概念了。通俗的说,它是一种数据的存储格式,就像PHP序列化后的字符串一样。它是一种数据描述。比如我们将一个数组 序列化后存放,就可以很容易的反序列化后应用。JSON也是如此,只不过他搭建的是客户端Javascript和服务端PHP的交互桥梁。我们用PHP生 成JSON后的字符串,然后把这个字符串传给前台Javascript,Javascirpt就可以很容易的将其反JSON然后应用。说通俗点,它真的很 像数组。
言归正传,如何使用JSON。PHP5.2开始内置了JSON的支持。当然,如果低于这个版本的话,那么市面上有很多PHP版本的实现,随便下一个用就OK啦。现在主要是说说PHP内置支持的JSON。很简单,两个函数:json_encodejson_decode(跟序列化很像啦)。一个编码,一个解码。先看看编码的使用:

<?php$arr = array(    ‘name‘ => ‘陈毅鑫‘,    ‘nick‘ => ‘深空‘,    ‘contact‘ => array(        ‘email‘ => ‘shenkong at qq dot com‘,        ‘website‘ => ‘http://www.chenyixin.com‘,    ));$json_string = json_encode($arr);echo $json_string;?>

  很简单的将一个数组JSON了。需要指出的是,在非UTF-8编码下,中文字符将不可被encode,结果会出来空值,所以,如果你使用gb2312编写PHP代码,那么就需要将包含中文的内容使用iconv或者mb转为UTF-8再进行json_encode,

时间: 2024-10-02 07:57:00

PHP ajax实现数组返回的相关文章

ajax交互servlet返回数据和jdbc模糊查询-中文-已经设置了UTF-8和解决了乱码

1.编码是将字符按一定翻译方式转换成字节存储在内存或外存中,解码是按照一定翻译方式将存储中的字节转换成字符. 2.ASCII是单字节,最高位总为0,相当于只占用了一个字节的7位,2^7=128个字符,相当于键盘上的128个键,有大小写因为字母,有*,%¥#@!+....等这些可显示字符,也有不可以显示的控制符F1,ctr... 而ISO-8859-1是启用了ASCII码的最高位,理论上是能再多128位,实际上没用掉这么多,至于多了那些,你们自己查下表 UTF-8是可变长的,具体中文几个字节,怎么

Spring 接收转换 jquery ajax json数组字符串

1.ajax发送json字符串 </pre><p>组建对象</p><p></p><pre code_snippet_id="449843" snippet_file_name="blog_20140813_2_7927326" name="code" class="javascript">var student = new Object(); studen

Ajax请求php返回json对象数据中包含有数字索引和字符串索引,在for in循环中取出数据的顺序问题

//php中的数组数据格式 Array ( [all] => Array ( [title] => ALL [room_promotion_id] => all ) [best_available_rate] => Array ( [title] => Best Available Rate [room_promotion_id] => best_available_rate ) [30] => Array ( [room_promotion_id] =>

在Ajax中将数组转换成字符串

主页面; <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>ajax查表格</title> <script src="../jquery-1.11.2.min.js"> </script> </head> <body> <div&

ajax接收php返回得到一堆html代码

ajax接收php返回得到一堆html代码 一.      错误代码: <font size='1'><table class='xdebug-error xe-notice' dir='ltr' border='1' cellspacing='0' cellpadding='1'> <tr><th align='left' bgcolor='#f57900' colspan="5"><span style='background-

jQuery的ajax调用webservice返回XML数据传参错误

jQuery的ajax调用webservice返回XML数据传参错误: 有时候使用jquery的ajax调用带有参数的webservice返回XML格式输出的时候,会出现传参错误,当然错误的原因可能是多种多样的,下面就简单介绍一种. 一.错误代码: 1.ajax代码: $.ajax({ type:"post", url:"_service.asmx/getDataFromATable", data:" { tablename: temp }",

jquery序列化form表单使用ajax提交后处理返回的json数据

这篇文章主要介绍了jquery序列化form表单,使用ajax提交后处理返回的json数据的示例,需要的朋友可以参考下 1.返回json字符串: ** 将一个字符串输出到浏览器 */    protected void writeJson(String json) {        PrintWriter pw = null;        try {            servletResponse.setContentType("text/plain;charset=UTF-8"

【.net ajax显示后台返回值】

1..net ajax显示后台返回值 <script>        $(document).ready(function () {            $("#btn").click(function () {                //var data = new string();                $.ajax({                    type: "POST",  //要用post方式           

spring ajax提交并返回数据方式

jsp $('#userId').change(function() { $.ajax({ url: "${ctx}/test/checkUser.do", contentType: "application/json;charset=utf-8", type: "get", data:{ userId:$("#userId").val() }, success: function(data) { if(data!=''){