Recursive implementation of tree catalog (1) Database + JSP + Javabean

xiaoxiao2021-03-14  209

Recursive implementation of the tree directory (1) Database JSP JavaBean <% @ page contentty = "text / html; charset = GB2312" Language = "Java" IMPORT = "java.sql. *" ErrorPage = "%> < ! - Database Structure: Table Name: Test Table Name: TreeCreate Table [DBO]. [Tree] ([Id] [INT] Identity (1, 1) Not Null, [ParentID] [INT] NOT NULL, [MESSAGE] [varchar] (50) collate chinese_prc_ci_as null) In order to achieve a better effect, the five small pictures are prepared here: Plus.gif minus: Minus.gif Opened folder: OpenFold.gif Close folder: ClosedFold .gif white board: White.gif -> <%! // This is not written here in JavaBean Class CN {// Connecting Database, here is MS-SQL as an example String JDBCDriver = "com.microsoft.jdbc.sqlserver. SQLServerDriver "; // JDBC Drive String Connectionstring =" JDBC: Microsoft: SQLServer: // localhost: 1433; // Database connection string String user = "sa"; // database username String pass = " "; // Database password connection conn = null; resultset = null;

Public CN () {Try {class.Forname (jdbcdriver);} catch (classnotfoundexception e) {system.err.println (e.tostring ());}}

public ResultSet executeQuery (String sql) {rs = null; try {conn = DriverManager.getConnection (connectionString, user, pass); Statement stmt = conn.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); rs = stmt.executeQuery (sql ); Catch (SQLEXCEPTION E) {system.err.println (e.tostring ());} Return Rs;}

public void executeUpdate (String sql) {try {conn = DriverManager.getConnection (connectionString, user, pass); Statement stmt = conn.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); stmt.executeUpdate (sql);} catch (SQLException e) {system.err.println (e.tostring ());}}}

Class Tree {CN CONN = New CN (); public void init (javax.servlet.jsp.jspwriter out, javax.servlet.http.httpservletRequest request) throws exception {Out.println (" with JSP tree </ Title> "); Dowith (Request); Buildtree (out, 0, 0); // Initial Call} Private void Dowith (Javax.Servlet.http.httpservletRequest Request) {if (Request.getParameter (" ParentID ") == Null || Request.getParameter ("ParentID"). Equals (")) Return; String Action = Request.getParameter (" action "); if (action.equals (" add ")) Conn.executeUpdate (" Insert Into Tree (Parentid, Message) Values ​​('" Request.getParameter (" ParentID ") "', '" Request.getParameter (" Message " ") "); Else IF (Action.equals (" delete ")) Conn.executeUpdate (" delete from tree where id = " Request.getParameter (" ParentID ") " Or ParentId = " Request.GetParameter (" ParentID "));}</p> <p>public void buildTree (javax.servlet.jsp.JspWriter out, int parentid, int level) throws Exception {level ; ResultSet rs = conn.executeQuery ( "select * from tree where parentid =" parentid "order by id"); while (rs.next ()) {OUT.Println ("<div>"); for (int i = 0; i <level-1; i ) out.print ("<img src =" white.gif ">" ); If (HAS_CHILD ("ID")))))) {out.print ("<img alt =" Expand "Style =" CURSOR: HAND; "οnclick =" myclick ('" rGETINT (" ID ") "); "ID =" img " rs.get (" ID ") " "src =" plus.gif "> <img id =" m " rs.getinT (" ID ") "" SRC = "ClosedFold.gif"> "); out.print (" <span οnclick = "myclick1 ('" rs.Getint ("ID") ");" style = "CURSOR: DEFAULT; "ID =" span " rs.Getint (" ID ") " "> rs.getstring (" message ") " ID = " rs.getint (" id ") " </ span> " ); Out.println ("<div style =" display: none; "ID =" div " gtint (" id ") " ">"); buildtree (out, rs.getint ("id") , Level); // Recursive call Out.println ("</ div>");} else out.print ("<img src =" minus.gif "> <img src =" openfold.gif "> <span οnclick = "MyClick1 ('" rs.getinT ("ID") ");" Style = "CURSOR: Default;" ID = "span" rs.getint ("ID") ""> rs.getstring ("message") "</p> <p>ID = " rs.Getint (" ID ") " </ span> "); OUT.PRINTLN (" </ div> ");} r r cclose (); rs = null;} private boolean HAS_CHILD (int) Parentid) THROWS Exception {ResultSet RS = Conn.executeQuery ("Select * from trentid =" ParentID "ORDER BY ID"); return rs.next ();}</p> <p>Public string getoption () throws exception {string Option = ""; ResultSet RS = conn.executeQuery ("SELECT * from tree order"); while (rs.next ()) Option = "<option value =" rs.getint ("ID") ""> rs.getint ("ID") "</ option>"; return option;}}%> <! - The above code can be written into JavaBean -> < Script language = "javascript"> <! - This JS in order to achieve the effect of the tree expansion and closing -> <! - function myclick (id) {EVAL ("VAR DIV = Div" ID); EVAL "VAR IMG = IMG" ID); EVAL ("VAR IM = IM" ID); div.style.display = div.style.display! = "none": "block": "block"; img.src = div.style.display! = "none"? "minus.gif": "plus.gif"; im.src = div.style.display! = "none"? "openfold.gif": "closedDFold.gif" Img.alt = div.style.display! = "None"? "Off": "Expand";} Function MyClick1 (ID) {document.form1.parentID.Value = ID;} // -> </ script > <table> <tr> <td height = "300" Valign = "TOP"> <% Tree mytree = new tree (); mytree.init (out, request);%> </ td> </ tr> < Tr> <TD Valign = "TOP"> <% IF (MyTree.Getoption (). Equals (")) {%> <form name =" form1 "action =" "Method =" get "> ParentID: 0- Represents root node Message: <input type = "text" name = "message"> <input type = "Hidden "name =" parentID "value =" 0 "> <input type =" submit "name =" action "value =" add "> </ form> <form name =" form1 "action = "</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-129471.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="129471" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.037</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'YpWrJSMEcRQjmEQHMYNnLRHhHWfaCvbTJcghlf8vXYUe7tTt1dG2fsWw19G3fhML_2F3u8CkrSVu515GePxcq1ow_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>