Solved

JQuery code to move one element before another

Posted on 2013-11-26
9
426 Views
Last Modified: 2013-11-26
Hi!

I'm VERY new to jquery, so please bear with me.

I need to move an element in my wordpress blog. The element is created by a plugin I use (called mailpoet), and the plugin author told me to use jquery to move it.

Here's the jquery I have:
$('p.form-submit').each(function() {
    $(this).insertAfter($(this).parent().find('p.wysija-after-comment'));
});

Open in new window


I also enqueued the .js file (and can see it in the page source), but for some reason, the element is not getting moved. I have no clue how to debug this to find the problem.

Here's the page: http://dev.goinspire.com/men-demand-equal-rights-jwrp/

The element to be moved is the "Post Comment" button, it should be after the checkbox where they can click to subscribe.

If anyone can help me I'd REALLY appreciate it.
0
Comment
Question by:etech0
  • 4
  • 4
9 Comments
 
LVL 82

Assisted Solution

by:leakim971
leakim971 earned 250 total points
ID: 39678466
Try this :
jQuery('p.form-submit').insertAfter('p.wysija-after-comment');

Open in new window

If it don't work this :
jQuery(document).ready(function() {
        jQuery('p.form-submit').insertAfter('p.wysija-after-comment');
});

Open in new window

If it don't work this :
jQuery(window).load(function() {
        jQuery('p.form-submit').insertAfter('p.wysija-after-comment');
});

Open in new window

like this
0
 
LVL 10

Author Comment

by:etech0
ID: 39678483
Thanks for your reply!

For some odd reason, none of them are working.

Note: I'm putting the jquery code into a file called submitbutton.js, and i'm enqueueing it via this:

wp_enqueue_script( 'submitbutton', get_template_directory_uri() . '/js/submitbutton.js', array( 'jquery' ), '',  true );

Open in new window

0
 
LVL 43

Expert Comment

by:Chris Stanyon
ID: 39678571
Your page is showing a 404 error (file not found) for this file:

http://dev.goinspire.com/wp-content/themes/goinspire/js/submitbutton.js

Check it exists and is in the right place.
0
Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

 
LVL 43

Expert Comment

by:Chris Stanyon
ID: 39678584
Once you've got your files sorted, this is the jQuery you'll need:

jQuery('#commentform .form-submit').appendTo('#commentform');

Open in new window

0
 
LVL 10

Author Comment

by:etech0
ID: 39678587
That's where it is.

Except that dev.goinspire.com points to goinspire.com/dev, so the file is really at goinspire.com/dev/wp-content-themes/goinspire/js/submitbutton.js

Do you think that would make a difference?
0
 
LVL 43

Accepted Solution

by:
Chris Stanyon earned 250 total points
ID: 39678606
That's where it is.
Sorry to dissappoint, but no it isn't. Open this in your browser:

http://dev.goinspire.com/wp-content/themes/goinspire/js/submitbutton.js

You will get a File Not Found error!

Whereas this works:

http://dev.goinspire.com/wp-content/themes/goinspire/js/smoothscroll.js

So the issue isn't one of mapping
0
 
LVL 10

Author Comment

by:etech0
ID: 39678614
You're right! So strange, because I'm using Sublime SFTP and it said the file was there, but when I looked in FileZilla I didn't see it, so I uploaded it from there.

Now the button is in the right place. Thanks!

Question: I'm using the third code option you gave. Any reason to try the others? (speed or something?)

Just curious...
0
 
LVL 43

Expert Comment

by:Chris Stanyon
ID: 39678655
It was leakim that provided the first set of examples, not me, but fundamentally all three of his suggestions are the same.

When you use any jQuery that operates on the DOM it's common practice to make sure the DOM is ready before firing the function - the standard way to do that is to use the document ready block - the second example.

As you're putting the code in it's own file, then I would suggest using the document ready method.

For the actual function that moves the button - doesn't really matter whether you use my method (append) or leakims (insertAfter) - just wrap either in jQuery(document).ready()
0
 
LVL 10

Author Closing Comment

by:etech0
ID: 39679067
Got it. Tremendous thanks to both of you for such clear, quick explanations!
0

Featured Post

Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Hi all! Recently there was EE question and the person wanted to have a multi-column textbox <div> selection, so as a first step to answer I provided a link but that was not complete with JavaScript selection, but had a good style sheet. So as a ques…
Introduction HyperText Transfer Protocol (http://www.ietf.org/rfc/rfc2616.txt) or "HTTP" is the underpinning of internet communication.  As a teacher of web development I have heard many questions, mostly from my younger students who have come to t…
The purpose of this video is to demonstrate how to exclude a particular blog category from the main blog page. This is can be used when a category already has its own tab, or you simply want certain types of posts not to show up on the main blog. …
The purpose of this video is to demonstrate how to Test the speed of a WordPress Website. Site Speed is an important metric of a site’s health. Slow site speed can result in viewers leaving your site quickly and not seeing your content. This…

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question