Edit in JSFiddle

// A* Pathfinding for HTML5 Canvas Tutorial 
// PART ONE: world generator ONLY:
// see http://jsfiddle.net/McFunkypants/eky9f/ for the full version
// by Christer (McFunkypants) Kaitila
// http://www.mcfunkypants.com
// http://twitter.com/McFunkypants

// Permission is granted to use this source in any
// way you like, commercial or otherwise. Enjoy!

// the game's canvas element
var canvas = null;
// the canvas 2d context
var ctx = null;
// an image containing all sprites
var spritesheet = null;
// true when the spritesheet has been downloaded
var spritesheetLoaded = false;

// the world grid: a 2d array of tiles
var world = [[]];

// size in the world in sprite tiles
var worldWidth = 16;
var worldHeight = 16;

// size of a tile in pixels
var tileWidth = 32;
var tileHeight = 32;

// ensure that concole.log doesn't cause errors
if (typeof console == "undefined") var console = { log: function() {} };

// the html page is ready
function onload() 
{
  console.log('Page loaded.');
  canvas = document.getElementById('gameCanvas');
  canvas.width = worldWidth * tileWidth;
  canvas.height = worldHeight * tileHeight;
  ctx = canvas.getContext("2d");
  spritesheet = new Image();
  // spritesheet.src = 'spritesheet.png';
  // the image above has been turned into a data url
  // so that no external files are required for
  // this web page - useful for included in a 
  // "gist" or "jsfiddle" page
  spritesheet.src = '';
  spritesheet.onload = loaded;
}

// the spritesheet is ready
function loaded() 
{
  console.log('Spritesheet loaded.');
  spritesheetLoaded = true;
  createWorld();
}

// fill the world with walls
function createWorld()
{
  console.log('Creating world...');
  
  // create emptiness
  for (var x=0; x < worldWidth; x++)
  {
    world[x] = [];
    
    for (var y=0; y < worldHeight; y++)
    {
      world[x][y] = 0;
    }
  }
  
  // scatter some walls
  for (var x=0; x < worldWidth; x++)
  {
    for (var y=0; y < worldHeight; y++)
    {
      if (Math.random() > 0.75)
        world[x][y] = 1;
    }
  }
  
  redraw();
  
}

function redraw() 
{
  if (!spritesheetLoaded) return;
  
  console.log('redrawing...');
  
  var spriteNum = 0;
  
  // clear the screen
  ctx.fillStyle = '#000000';
  ctx.fillRect(0, 0, canvas.width, canvas.height);
  
  for (var x=0; x < worldWidth; x++)
  {
    for (var y=0; y < worldHeight; y++)
    {
      // choose a sprite to draw
      switch(world[x][y])
      {
        case 1: 
          spriteNum = 1; 
          break;
        default:
          spriteNum = 0; 
          break;
      }
      
      // draw it
      // ctx.drawImage(img,sx,sy,swidth,sheight,x,y,width,height);
      ctx.drawImage(spritesheet, 
                    spriteNum*tileWidth, 0, 
                    tileWidth, tileHeight,
                    x*tileWidth, y*tileHeight,
                    tileWidth, tileHeight);
      
    }
  }
}


// start running immediately
onload();
<div>
  Random World Generator by 
  <a href='http://twitter.com/McFunkypants'>@McFunkypants</a>
  <input type='button' onClick='createWorld()' value='New World'>
</div>

<div><canvas id="gameCanvas"></canvas></div>
		body { padding:0; margin:0; height:100%; width:100%; }
		div { font-family:arial; font-size:16px; font-weight:bold; text-align:center; }