简体   繁体   中英

Pass JSON from php to javascript

I want to localize my webapp. Since localization through javascript only is not recommended I thought using php would be an alternative.

So with php I read a messages.json file that stores all localization data.

$json = file_get_contents("_locales/en/messages.json");

In the header of my webapp I generate some javascript with php according to the user's browser language.

echo "var localeObj = " . $json . ";";

So this is just a var that holds all data from the m essages.json file that looks like that

{
    "extTitle": {
        "message": "Test1"
    },
    "extName":{
        "message": "Test2"
    }
}

Now I want to be able to access each item from the json like

var title = getItem("extTitle");

and it returns Test1 . Any idea how to do that?

I am not very familar with json but if I just alert the localeObj it gives me just [object Object].

var getItem = function(item) {
   return localObj[item].message;
};

You could always encapsulate your i18n strings too...

(function() {

   var localObj = { ... };

   window.getItem = function(item) {
       return localObj[item].message;
   };

})();

This way, no other variables can possibly clobber your localObj .

You use array syntax [] , or dot syntax . , to access javascript object properties.

Example:

localeObj["extTitle"];
localeObj.extTitle;

I would recommend reading something like this to get more familier with JSON.

You can initialize javascript variable like this.

var json = eval(<? echo $json ?>);   
alert(json.extTitle.message+ '  '+json.extName.message);

Inside messages.php :

<?php
header('Content-type:application/javascript');
$messages = array(
 "yes"=>"hai",
 "no"=>"iie"
);
$messages = json_encode($messages);
echo "window.messages = $messages";
?>

Inside index.html :

<html>
 <body>
 <script type="text/javascript" src="messages.php"></script>
 <script type="text/javascript">
  console.log(window.messages)
 </script>
 </body>
</html>

As long as you tell the browser to interpret the php file as a javascript file, you can echo anything you want.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM