Kendall Weihe Kendall Weihe - 1 year ago 141
HTML Question

JQuery clone li+children, update text (in child tag), and append

I have some pretty cool CSS that I want to reuse in a

. I want to clone an existing
(so that I can reuse CSS), update a
field, and then append it to the end of the

I know I can do something like this to find...

var temp = $(".chatboxcontent").find('li');

And then I can use
like so... (is this correct?)

var temp2 = temp.clone

So then I need to delete a
and then insert my own

The HTML element looks like this...

<div class="chatboxcontent">
<li class="current-user-message">
<div class="avatar">
<img src="">
<div class="chatboxmessagecontent">
<time datetime="2016-07-28 16:45:20 UTC" title="28 Jul 2016 at 04:45PM">
16:45 PM
<li class="current-user-message">
<div class="avatar">
<img src="">
<div class="chatboxmessagecontent">

...and so on

I need to delete then insert text in the
element and then append it to the

I'm thinking something like this...

var message_li = $(".chatboxcontent").find('li').clone();
$(message_li).innerHTML("p") = data.text;

From the above I get
$(...).innerHTML is not a function
. So how do I delete the element and then insert it?

Is there a better way to implement this?

Answer Source

You can try this:

$(".chatboxcontent") //Select the conatiner
.find('li:first') //Find the first 'li' element
.clone() //then clone it
.find('p') //Find the 'p' tag inside the cloned element
.html(data.text) // change the html of the 'p' tag
.end() // Return to the cloned 'li' with the 'p' tag changed
.appendTo('.chatboxcontent'); // append the cloned 'li' to the conatiner


I hope this will help.

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download