I have the following array and I want to create an unordered list from it, but I had a problem creating an unordered list in the appropriate format. I was looking for similar questions, but none of the existing solutions work for my problem.
var myArray = ['Value 1', ['Inner value 1', 'Inner value 2', 'Inner value 3', 'Inner value 4'], 'Value 2', 'Value 3', 'Value 4', 'Value 5', 'Value 6'];
Here is my JavaScript code:
function arrToUl(arr) { var div = document.getElementById('myList'); var ul = document.createElement('ul'); for (var i = 0; i < arr.length; i++) { if (arr[i] instanceof Array) { var list = arrToUl(arr[i]); } else { var li = document.createElement('li'); li.appendChild(document.createTextNode(arr[i])); console.log(ul.appendChild(li)); } div.appendChild(ul); } } arrToUl(myArray);
The above code gives the following result:
<ul> <li>Value 1</li> <li>Inner Value 1</li> <li>Inner Value 2</li> <li>Inner Value 3</li> <li>Inner Value 4</li> <li>Value 2</li> <li>Value 3</li> <li>Value 4</li > <li>Value 5</li > <li>Value 6</li>
But the result should look like this:
<ul> <li>Value 1 <ul> <li>Inner Value 1</li> <li>Inner Value 2</li> <li>Inner Value 3</li> <li>Inner Value 4</li> </ul> </li> <li>Value 2</li> <li>Value 3</li> <li>Value 4</li> <li>Value 5</li> <li>Value 6</li>
Thank you for your help.
source share