Solved

Just wanted to get some feedback on the methodology of how I use Coldfusion and (jQuery) $.ajaxy goodness..

Posted on 2014-03-08
5
205 Views
Last Modified: 2014-03-09
I'm curious if this is a standard way of doing this with Coldfusion + $.ajax. It seems that my code gets a little bloated from this way. And again my question is really just to explore other ways to not have full page refreshes.
<!DOCTYPE html>
<html>
<head>
	<title></title>
</head>
<body>


<div class="loadData"></div>

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>

<script>
$(document).ready(function() {
	$(".loadData").load("mydata.cfm");
});

I might have other functions here that specifically work for a few unrelated items in the "loadData" content area.

</script>


</body>
</html>

#### mydata.cfm 

<!--- I usually create .cfc's for retrieving data but for simplicty I'm adding it here --->
<cfquery>
	SELECT *
	FROM TABLE
</cfquery>

<cfoutput>
#data# I could have functionality like deleting or updating to where I utilize jquery as well.
</cfoutput>

<script>
     I might have functions here that seem to only specifically work for this pages functionality here. Which makes sense (DOM) but I'm just exploring other ways to possibly handle the ajax awesomeness as I've mentioned above.
</script>

Open in new window

0
Comment
Question by:brihol44
  • 2
  • 2
5 Comments
 
LVL 25

Expert Comment

by:dgrafx
ID: 39915703
are you asking if using $(".loadData").load("mydata.cfm"); to populate elements is ok - or is there a better way?

my opinion is that it is ok.

myself i might do the following instead though:

<div class="loadData"><cfinclude template="mydata.cfm"></div>
then to refresh it on some event i would reload it using using the $("#someelement").on('click', function() { $(".loadData").load("mydata.cfm"); } }); ...
(that's just for example)

OR if your question is different than that could you clarify please.

good luck ...
0
 
LVL 15

Assisted Solution

by:Gurpreet Singh Randhawa
Gurpreet Singh Randhawa earned 100 total points
ID: 39915754
The way @dgrafx told you and you working is the best method if you want to implement ajax with coldfusion.

If you want to explore other ways, use javascript mvs frameworks like AngularJS, KnockoutJS, Batman for writing same code in more MVC manner so you can get the relevant Output

Regards
0
 

Author Comment

by:brihol44
ID: 39915954
ok, thx. Just two questions: 1. Is it common to have specific javascript functions for say your "mydata.cfm" on that page? Seems like I have to add in some functions specifically used on that page at the bottom. Ideally it would be nice to just have one main scripts.js file for less clutter in the head or footer but I'm guessing the DOM of mydata.cfm loads differently so maybe that's just how it is.

<cfoutput> stuff...

<script>
 Do stuff...
</script>

2. Your method of the ".load" what advantage is that over the way I'm doing it? Just curious.

Thank you!
0
 
LVL 25

Accepted Solution

by:
dgrafx earned 400 total points
ID: 39915975
1. yes - create a master .js file - less clutter - stay organized
plus you do not want to add js functions in your mydata file - spaghetti code ya know ...
just like in CF you want to keep your functions in a cfc and all your cfcs in one location

2. using .on(...) will allow you to access dynamically written elements.
this may be a problem you've possibly encountered in the past ...
0
 

Author Closing Comment

by:brihol44
ID: 39916002
Awsome! Thx... that's exactly what I was looking for. Less spaghetti and more sauce.
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

PROBLEM: How to add your own buttons to the bottom toolbar with paging info ( result count ). While creating a cfgrid, I ran into an issue where I wanted to embed my own custom buttons where the default ones ( insert / delete / etc… ) are for aes…
Today, I was working on some optimization and spam-stopping techniques when I encountered Ben Nadel's post to reduce spam feature using Math (http://www.bennadel.com/blog/197-How-I-Stop-Spammers-On-My-ColdFusion-Blog.htm). While this method is not o…
Illustrator's Shape Builder tool will let you combine shapes visually and interactively. This video shows the Mac version, but the tool works the same way in Windows. To follow along with this video, you can draw your own shapes or download the file…
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.

760 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

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now