convertir matriz asociativa php en object javascript

Intento cargar palabras en chino como keys y sus traducciones al inglés como valores de una database en una matriz php para poder usarlas en el lado del cliente en JavaScript. Así que cargué la key PHP: pares de valores en la matriz de JavaScript y trato de generar los resultados como par de valores key como tal:

stuff : Ni, You stuff : Ta, Him or Her stuff : Wo, I 

Las palabras en chino e inglés se cargan en una database relacional.

PHP :

 $wordsArray = array(); while ($row = $sql->fetch_assoc()) { $wordsArray[$row['chinese']] = $row['english']; } 

Javascript : Aquí quiero que $ .each muestre la key como una cadena y no como un índice numérico. Así que cuando probé var words = [<?php echo '"'.implode('","', $wordsArray).'"' ?>]; como una matriz, obtuve:

 stuff : 0, You stuff : 1, Him or Her stuff : 2, I 

Cuando realmente estoy buscando:

 stuff : Ni, You stuff : Ta, Him or Her stuff : Wo, I 

Así que cambié las words para que fueran un object, de modo que $.each pudiera dar salida a la key como cadena:

 var words = {<?php echo '"'.implode('","', $wordsArray).'"' ?>}; $.each(words, function(key, value) { console.log('stuff : ' + key + ", " + value); }); 

Que arroja el error: SyntaxError: Unexpected token ,

Puede usar json_encode () para hacer una array como un json object como,

 var words = <?php echo json_encode($wordsArray) ?>;// don't use quotes $.each(words, function(key, value) { console.log('stuff : ' + key + ", " + value); }); 

Busqué una solución elegante para solucionar este problema sin hacer cambios en JavaScript o simplemente replace citas mediante preg_replace (para el caso de que los valores contengan comillas) y termine haciéndolo solo. incluso si es demasiado tarde, espero que ayude a quienes buscan la misma solución.

 function json_encode_advanced(array $arr, $sequential_keys = false, $quotes = false, $beautiful_json = false) { $output = "{"; $count = 0; foreach ($arr as $key => $value) { if ( isAssoc($arr) || (!isAssoc($arr) && $sequential_keys == true ) ) { $output .= ($quotes ? '"' : '') . $key . ($quotes ? '"' : '') . ' : '; } if (is_array($value)) { $output .= json_encode_advanced($value, $sequential_keys, $quotes, $beautiful_json); } else if (is_bool($value)) { $output .= ($value ? 'true' : 'false'); } else if (is_numeric($value)) { $output .= $value; } else { $output .= ($quotes || $beautiful_json ? '"' : '') . $value . ($quotes || $beautiful_json ? '"' : ''); } if (++$count < count($arr)) { $output .= ', '; } } $output .= "}"; return $output; } function isAssoc(array $arr) { if (array() === $arr) return false; return array_keys($arr) !== range(0, count($arr) - 1); } 

uso:

 $array = [ 'someField' => '"value"', // double quotes for string if needed 'labelField' => '"label"', // double quotes for string if needed 'boolean' => false, 'numeric' => 5, 'render' => [ 'option' => 'function() { console.log("Hello World!"); console.log(\'Hello World!\'); }', ], ]; echo json_encode_advanced($array); 

resultado:

 { someField : "value", labelField : "label", boolean : false, numeric : 5, render : { option : function() { console.log("Hello World!"); console.log('Hello World!'); } } } 

Solo cambié algunas cosas para hacerlo más compatible (líneas 3 y 29):

 function json_encode_advanced(array $arr, $sequential_keys = false, $quotes = false, $beautiful_json = false) { $output = isAssoc($arr) ? "{" : "["; $count = 0; foreach ($arr as $key => $value) { if (isAssoc($arr) || (!isAssoc($arr) && $sequential_keys == true )) { $output .= ($quotes ? '"' : '') . $key . ($quotes ? '"' : '') . ' : '; } if (is_array($value)) { $output .= json_encode_advanced($value, $sequential_keys, $quotes, $beautiful_json); } else if (is_bool($value)) { $output .= ($value ? 'true' : 'false'); } else if (is_numeric($value)) { $output .= $value; } else { $output .= ($quotes || $beautiful_json ? '"' : '') . $value . ($quotes || $beautiful_json ? '"' : ''); } if (++$count < count($arr)) { $output .= ', '; } } $output .= isAssoc($arr) ? "}" : "]"; return $output; }