Group Li Into Ul Based On Dash '-' July 02, 2024 Post a Comment I got a code dropdown like this: Top Folder2nd Folder 01 &lSolution 1: Yes, you should be able to use the dashes, provided that the level is always the number of dashes divided by three. The key is to use a stack. It also helps to have a function to count the dashes.// Helper function.functioncountLeadingChars(str, ch) { for (var i = 0; i < str.length; i++) { if (str.charAt(i) !== ch) { return i; } } return str.length; } var stack = []; $('#Folder').children().each(function() { var$option = $(this); var text = $option.text(); // Count the dashes.var dashes = countLeadingChars(text, '-'); // Level is # of dashes divided by 3.var level = dashes / 3; // Remove anything in the stack beyond the current level.// This will cause new <ul>s to get created when higher// levels are encountered again.if (stack.length > (level + 1)) { stack.length = level + 1; } // Get the <ul> for the level, creating it if it doesn't exist.var$ul = stack[level]; if (!$ul) { $ul = $('<ul/>'); stack[level] = $ul; // Add the <ul> to the last <li> of the parent <ul>.if (level > 0) { stack[level - 1].children(':last').append($ul); // Add the "class" to the <ul>.var parentText = $ul.parent().text(); var index = parentText.lastIndexOf(' '); $ul.addClass('something' + parentText.slice(index + 1)); } } // Create the <li> and add it to the <ul>. $('<li>' + text.slice(dashes) + '</li>').appendTo($ul); }); // At this point, stack[0] is the top-most <ul>.CopyLive Demo on jsfiddleEDIT: I just noticed you wanted a "class" on the <ul> elements I added the code for that above.New Live Demo on jsfiddleSolution 2: See the tag optgroup and if it solves your problemhttp://www.w3schools.com/tags/tag_optgroup.asp Share Post a Comment for "Group Li Into Ul Based On Dash '-'" Top Question Possible To Scroll Caret Into View Inside A Single HTML Text Field With JavaScript? Knowing the jQuery Caret plugin, I'm still seeing no wa… Ondragstart Not Triggering In Firefox Hello I'm trying to use the html drag and drop feature … How To Specify Color Space For Canvas In JavaScript? What is the default color space used in JS canvas? How can … How To Change Select Tag Value When Other Select Is Change? My HTML page contents two select options as follows. It h… After Selecting One Radio Button, I Want The Remaining Buttons To Become Disabled I am working on a pong game in java script where one can ch… Efficiently Representing A Large Grid In A Browser I need to display and manipulate, in a browser, a grid of u… Use Same Header And Footer On All Webpages I'm working on an ASP.NET website, which I'm buildi… What Is The Correct Way For Redirecting From The Domain Name Itself To A Page In A Directory? I want anyone browsing for 'MyDomain.com' to see wh… PHP Scandir Function With HTML Form (Checkboxes) I have a directory that contains various files, .txt, .xls,… Playing Music In An Email Yes, I know. It sounds utterly impossible, and to the best … November 2024 (36) October 2024 (49) September 2024 (14) August 2024 (197) July 2024 (174) June 2024 (412) May 2024 (679) April 2024 (415) March 2024 (764) February 2024 (837) January 2024 (751) December 2023 (821) November 2023 (346) October 2023 (564) September 2023 (271) August 2023 (306) July 2023 (274) June 2023 (327) May 2023 (203) April 2023 (144) March 2023 (129) February 2023 (162) January 2023 (274) December 2022 (133) November 2022 (226) October 2022 (179) September 2022 (159) August 2022 (286) July 2022 (93) Menu Halaman Statis Beranda © 2022 - Html5 Developer