所以我有一个多维数组,如下所示:
var map = [[0, 0, 0, 0, 0, 0, 0],
[0, 3, 0, 0, 2, 0, 0],
[0, 0, 0, 0, 4, 0, 4],
[0, 0, 0, 0, 5, 0, 5],
[0, 0, 0, 0, 0, 0, 1],
[0, 0, 2, 5, 0, 0, 0],
[0, 0, 0, 2, 0, 0, 0],
[0, 4, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0]];
我想将它保存到我的XML文件中。
我的XML文件如下所示:
<TileMaps>
<Level> <!-- Level 1 -->
<map>[[1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
[1, 3, 2, 4, 0, 0, 0, 0, 0, 1],
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1]]</map>
</Level>
<Level> <!-- Level 2 -->
<map>[[1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
[1, 3, 2, 4, 0, 0, 0, 0, 0, 1],
[1, 0, 2, 4, 0, 0, 0, 0, 0, 1],
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1]]</map>
</Level>
</TileMaps>
所以当我添加数组时,我希望它放在:
中的XML文件中<Level><map> ARRAY HERE </map></Level>
由于
答案 0 :(得分:2)
建议使用JSON。无论如何,如果你想继续使用XML,给出一个解决方案。
数组到XML
使用字符串连接构建XML字符串。使用Crockford's JSON library构建数组字符串。
var map = [[0, 0, 0, 0, 0, 0, 0],
[0, 3, 0, 0, 2, 0, 0],
[0, 0, 0, 0, 4, 0, 4],
[0, 0, 0, 0, 5, 0, 5],
[0, 0, 0, 0, 0, 0, 1],
[0, 0, 2, 5, 0, 0, 0],
[0, 0, 0, 2, 0, 0, 0],
[0, 4, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0]];
var xml = '<TileMaps><level><map>';
xml += JSON.stringify(map);
xml += '</map></level></TileMaps>';
alert(xml);
jsfiddle:http://jsfiddle.net/diode/ZfWjp/
然后将其发送到服务器端进行保存。
XML to Array
从服务器加载保存的XML。
使用jQuery解析它。
var xml = '<TileMaps><level><map>[[0,0,0,0,0,0,0],[0,3,0,0,2,0,0],[0,0,0,0,4,0,4],[0,0,0,0,5,0,5],[0,0,0,0,0,0,1],[0,0,2,5,0,0,0],[0,0,0,2,0,0,0],[0,4,0,0,0,0,0],[0,0,0,0,0,0,0]]</map></level></TileMaps>';
var map = $.parseJSON($(xml).find("map").text());
alert(map[0]);
alert(map[1]);
jsfiddle:http://jsfiddle.net/kBrCT/1/
注意:如果单个XML文件中有多个地图节点,则必须修改此项。
答案 1 :(得分:0)
如果它只是将数组本身转换为字符串,那么你可以这样做:
var data = [[0, 0, 0, 0, 0, 0, 0],
[0, 3, 0, 0, 2, 0, 0],
[0, 0, 0, 0, 4, 0, 4],
[0, 0, 0, 0, 5, 0, 5],
[0, 0, 0, 0, 0, 0, 1],
[0, 0, 2, 5, 0, 0, 0],
[0, 0, 0, 2, 0, 0, 0],
[0, 4, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0]];
var dataAsString = "[" + data.map(function(item){return "["+item.toString()+"]"}).toString() + "]"
console.log(dataAsString);
注意:地图是Javascript的最新补充,它可能无法在每个浏览器中使用(c.f. Mozilla Docs)
答案 2 :(得分:0)
这是我的解决方案,它在后端使用PHP和JSON,因此您需要根据需要修改服务器端代码(如果用XML封装JSON,您还需要调整语法中的语法) AJAX件)...哦,根据您的目标用户,您需要为输入(客户端和服务器端)添加一些验证:
PAGE:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Maker</title>
<style>
#can{width:300px; height:90px; display:block; background-color:#666;}
</style>
</head>
<body>
Which level do you want:<input type="text" id="level_request" value="level1"/><button onclick="init()">Go</button>
</body>
<script>
function saveLevel(){
ajax=((window.XMLHttpRequest)?new XMLHttpRequest():new ActiveXObject("Microsoft.XMLHTTP"));
name=document.getElementById('level_name').value; //this grabs the content in the Level Name field
if(name.length>0){
ajax.onreadystatechange=function()
{
if (ajax.readyState==4&&ajax.status==200){
alert('Level saved');
}
}
params='level='+name+'&map='+JSON.stringify(map); //this constructs the message to send, consisting of the name and map
ajax.open("POST","levels.php",true); //this is the file you will be POSTing a message to
ajax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
ajax.setRequestHeader("Content-length", params.length);
ajax.setRequestHeader("Connection", "close");
ajax.send(params);
}
}
var blocksize=30;
var map=[[1,1,1,1,1,1,1,1,1,1],[1,3,0,0,0,0,2,4,0,1],[1,1,1,1,1,1,1,1,1,1]];
var can;
var ctx;
function init(){
ajax=((window.XMLHttpRequest)?new XMLHttpRequest():new ActiveXObject("Microsoft.XMLHTTP"));
ajax.onreadystatechange=function()
{
if (ajax.readyState==4){ //this test whether the request is complete
l=document.getElementById('level_request').value;
document.body.innerHTML='Level Name:<input type="text" id="level_name" /><br/><canvas id="can" width="300" height="90"></canvas><br/><button onclick="saveLevel()">Save</button>'; //this replaces the initial form
can=document.getElementById('can')
if(can){ctx=can.getContext('2d');}
if(ajax.status==200){ //this test whether it was successful
m=JSON.parse(ajax.responseText);//this overwrites the existing map with the received data
console.log(m);
map=m.tilemaps[l];
for(y=0;y<map.length;y++){
for(x=0;x<map[y].length;x++){
draw(y,x);
}
}
can.addEventListener('click',builder);
}
else{ //this is what we do if the request is done and it was a failure
for(y=0;y<map.length;y++){
for(x=0;x<map[y].length;x++){
draw(y,x);
}
}
can.addEventListener('click',builder);
alert('Something went wrong, loading default level');
}
}
}
ajax.open("GET","levels.php?level="+document.getElementById('level_request').value,true);
ajax.send();
}
function builder(e){
if (e == null) {e = window.event;}
x = e.clientX; //where the click was
y = e.clientY;
offsetX = ExtractNumber(can.offsetLeft);//where the canvas is
offsetY = ExtractNumber(can.offsetTop);
x_grid=Math.floor((x-offsetX)/blocksize); //which block in the canvas was clicked
y_grid=Math.floor((y-offsetY)/blocksize);
map[y_grid][x_grid]++;
if(map[y_grid][x_grid]>4){map[y_grid][x_grid]=0;}
draw(y_grid,x_grid);
}
function draw(y,x){
kind=map[y][x];
switch(kind){
case 0:
ctx.drawImage(floorimg,x*blocksize,y*blocksize);
break;
case 1:
ctx.drawImage(wallimg,x*blocksize,y*blocksize);
break;
case 2:
ctx.drawImage(blockimg,x*blocksize,y*blocksize);
break;
case 3:
ctx.drawImage(playerimg,x*blocksize,y*blocksize);
break;
case 4:
ctx.drawImage(goalimg,x*blocksize,y*blocksize);
break;
}
}
function ExtractNumber(value){
var n = parseInt(value);
return n == null || isNaN(n) ? 0 : n;
}
var floorimg=new Image();
floorimg.src='';
var wallimg=new Image();
wallimg.src='';
var blockimg=new Image();
blockimg.src='';
var playerimg=new Image();
playerimg.src='';
var goalimg=new Image();
goalimg.src='';
</script>
</html>
levels.php:
<?php
if($_REQUEST['level']&&$_REQUEST['map']){
$file=file_get_contents('levels.txt'); //get the existing content
$json=json_decode($file); //convert it from string to object
$tilemaps=$json->tilemaps;
$tilemaps->$_REQUEST['level']=json_decode($_REQUEST['map']);
$o['tilemaps']=$tilemaps;
$str=json_encode($o);
$pos=fopen('levels.txt','w');
fwrite($pos,$str);
fclose($pos);
}
else{
header('content-type:application/json');
echo file_get_contents('levels.txt');
}
?>