2014-11-24 90 views
0

我想从php格式的导入io中获取数据,但是这并不适用于分页,所以必须在javascript(代码如下)中做到这一点,但我需要把它到一个数据库,所以我想PHP会是最好的(或至少对我来说最简单)。我的问题是如何将一个JavaScript数组转换为一个PHP数组。转换Javascript数组到PHP阵列

感谢,

MsKazza

<!DOCTYPE html> 
<html> 
<head> 
    <title>Import&bull;io Example</title> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script> 
<!-- 1. Include the client library --> 
    <script src="https://cdn.import.io/js/2.0.0/importio.js"></script> 

<!-- 2. Configure the library --> 
    <script type="text/javascript"> 
    importio.init({ 
     "auth": { 
     "userGuid": "4e3524b0-5ff7-4102-9710-f96246a8303c", 
     "apiKey": "oX9ksC/OQXxeO6dXYlNTgl8Juuh2SkCpdih2f0xH9d+3tzoBT0CsFuLr+ZlWPxVLbylL9XHQ8dLxNJvrKc2AUg==" 
     }, 
     "host": "import.io" 
    }); 

    // Data and done callbacks 
    var dataCallback = function(data) { 
     console.log("Data received", data); 
     for (var i = 0; i < data.length; i++) { 
     var d = data[i]; 
     for (var k in d.data) { 
      document.write("<i>" + k + "</i>: " + d.data[k] + "<br />"); 
     } 
     document.write("<hr>"); 
     } 
    } 
    var doneCallback = function(data) { 
     console.log("Done, all data:", data); 
     document.write("<b>Done</b><hr>"); 
    } 

// 3. Do the query (when the function is called) 
    var doQuery = function() { 
     // Query for tile goldenwherewhen 
     importio.query({ 
     "connectorGuids": [ 
      "83c211ab-91a1-4e54-9838-dc086bc1b527" 
     ], 
     "input": { 
      "what": "hotels", 
      "where": "ireland" 
     } 
     }, { "data": dataCallback, "done": doneCallback }); 

    } 
    </script> 
    <style>body { text-align: center; } button { line-height: 20px; color: #333; text-align: center; text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75); vertical-align: middle; cursor: pointer; border: 1px solid #CCC; -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff',endColorstr='#ffe6e6e6',GradientType=0); filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05); -moz-box-shadow: inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05); outline: 0; padding: 11px 19px; font-size: 17.5px; -webkit-border-radius: 6px; -moz-border-radius: 6px; border-radius: 6px; color: #FFF; text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); background-color: #EC3C87; background-image: -moz-linear-gradient(top,#EE4E93,#E92076); background-image: -webkit-gradient(linear,0 0,0 100%,from(#EE4E93),to(#E92076)); background-image: -webkit-linear-gradient(top,#EE4E93,#E92076); background-image: -o-linear-gradient(top,#EE4E93,#E92076); background-image: linear-gradient(to bottom,#EE4E93,#E92076); background-repeat: repeat-x; border-color: #E92076 #E92076 #AC1153; border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffee4e93',endColorstr='#ffe92076',GradientType=0); filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); }</style> 
    <body> 
    <button onClick="doQuery()">Query</button> 
    <p style="margin-top: 0"><img alt="" src="" /></p> 
    </body> 
</html> 
+1

我没有看到数组。我只看到一大块代码。我们是否应该执行它来查看数组的外观? – GolezTrol 2014-11-24 11:16:56

+0

我不会浪费太多时间查看代码,但我建议您使用JSON。将数组转换为JSON字符串,然后将其发送到PHP,并使用json_decode()将其转换为数组。请参阅:http://php.net/manual/en/function.json-decode.php – Tauri28 2014-11-24 11:20:55

+0

这个问题在这里回答。 http://stackoverflow.com/questions/9880904/javascript-array-converted-to-a-php-array – Aditya 2014-11-24 11:21:58

回答

0

您可以在许多方面做到这一点,两个 “最佳” 是

1,发送变量格式variable[key] = value PHP将reconise这并进行转换,以便$_GET['variable']['key']将包含valuehttp://php.net/manual/en/language.variables.external.php

2,将其作为一个JSON字符串使用JSON.stringify(yourArray);(注:IE8及以上版本支持这一点,旧版本需要一个像json2一个libary),然后在该变量PHP调用json_decode()。 http://php.net/manual/en/function.json-decode.php