Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
		<title>PROGRAMMATIC - Dojo Widget Creation Test</title>
		<script type="text/javascript" src="../../dojo/dojo.js"></script>
		<script type="text/javascript" src="../dijit.js"></script>
		<script type="text/javascript">
			var queryCount =\d*)/);
			var count = (queryCount ? parseInt(queryCount[1]) : 100);
			var queryClass =[a-zA-z.]*)/);
			var className = (queryClass ? queryClass[1] : "form.Button");

			dojo.require("dijit." + className);
			logMessage = window.alert;
		<style type="text/css">
			@import "../themes/tundra/tundra.css";
			/* group multiple buttons in a row */
			.box {
				display: block;
				text-align: center;
			.box .dojoButton {
				width: 80px;
				margin-right: 10px;
			.dojoButtonContents {
				font-size: 1.6em;

			#buttonContainer {
				border: 1px solid black;
				width: 100%;

			#results {
				color: darkred;
	<body class=tundra>
		<script language='javascript'>
			document.write("<h2>Currently Creating "+count+" "+className+" instances</h2>");
		Pass <code>?count=<i><b>100</b></i></code> in the query string to change the number of widgets.<br>
		Pass <code>?class=<i><b>form.Button</b></i></code> in the query string to change the widget class.
		<h3 id="results"></h3>

		<div id="buttonContainer" class='box'></div>
		<script type="text/javascript">
			// See if we can make a widget in script and attach it to the DOM ourselves.
			var constructor = dojo.getObject("dijit."+className);
			function makeEm(){
				var container = dojo.byId("buttonContainer");
				var t0 = new Date().getTime();
				for (var i = 1; i <= count; i++) {
					var it =
						new constructor(
								{label:"Button "+i, onclick:'logMessage("clicked simple")'}
					container.appendChild(it.domNode); = '';
				var t1 = new Date().getTime();
				dojo.byId("results").innerHTML = "It took " + (t1 - t0) + " msec to create " + count + " "+className+" instances programmatically.";
New to GrepCode? Check out our FAQ X