[lnkForumImage]
TotalShareware - Download Free Software

Confronta i prezzi di migliaia di prodotti.
Asp Forum
 Home | Login | Register | Search 


 

Forums >

comp.lang.ruby

AJAX without Rails

Miki Vz

11/20/2007 4:35:00 PM

Hi, I'm pretty new to Ajax.

I need to do some simple web interfaces for some project I have. A
friend told me Rails was a bit to much for what I need, so I'm using
eruby and markaby, and I'm pretty happy, and things are kept pretty
sweet and simple for now.

However I would like to use a little of Ajax, what is the best way to go
about it? How do Ajax work for ruby? seems like rails has support for
Ajax that makes it simple. Can i have the same for my eruby scripts
without having to install any MVC system like Rails or anything?

I would basically would like to use Ajax to send parts of the page to be
process on the server and use the results to modify how this parts are
shown. For example, send a paragraph from the page to perform named
entity extraction, and then use the results to highlight these named
entities.

Thanks for your time.

- mikisvaz
--
Posted via http://www.ruby-....

5 Answers

Miki Vz

11/20/2007 5:04:00 PM

0

Actually, I'm not sure I'm using eruby, I'm using mod_ruby and
generating the html with markaby. I'm a bit lost with all the technology
:p.
--
Posted via http://www.ruby-....

Eivind Eklund

11/21/2007 11:54:00 AM

0

On Nov 20, 2007 5:34 PM, Miki Vz <mikisvaz@yahoo.com> wrote:
> Hi, I'm pretty new to Ajax.
>
> I need to do some simple web interfaces for some project I have. A
> friend told me Rails was a bit to much for what I need, so I'm using
> eruby and markaby, and I'm pretty happy, and things are kept pretty
> sweet and simple for now.
>
> However I would like to use a little of Ajax, what is the best way to go
> about it? How do Ajax work for ruby? seems like rails has support for
> Ajax that makes it simple. Can i have the same for my eruby scripts
> without having to install any MVC system like Rails or anything?

AJAX is fairly simple, at least as long as you ignore the "XML" part
of it and use HTML or JSON (Javascript Over Network) to deal with it.

The very easiest way to do AJAX is to just have a new command
handler/new script that output the HTML you want to replace with, and
do something like this (example with the jQuery library):

<!-- Include jQuery library, replace with your own copy -->
<script type=3D"text/javascript"
src=3D"/publish/files/jquery-nightly-20070801.js"></script>

<!-- Add a method to jQuery for pure replace; this can also be done
other ways, I just included this because this is how my code was
structured already -->
<script type=3D"text/javascript">
jQuery.fn.replace =3D function() {
var stack =3D [];
return this.domManip(arguments, true, 1, function(a){
this.parentNode.replaceChild( a, this );
stack.push(a);
}).pushStack( stack );
};
</script>

<!-- Actual AJAX (actually, AJAH - Asynchronous Javascript And HTML) -->
<!-- Notice: the ready setup here is to call this stuff when the page
DOM is ready.
What happens here is that the POST equivalent of
approve.wa2?_cmd=3Dclose_edition;EditionId=3D2747 gets called,
outputs some HTML, and the #editioncloser input element shown
below gets replaced with
whatever that HTML describes. You can trivially replace what
script gets called, what args it takes, and which element it replace.
-->
<script type=3D"text/javascript">
<!--
$(document).ready(function(){
$("#editioncloser").click(function(){
$.post("approve.wa2", { EditionId: 2474, _cmd: "close_edition" },
function(data) {
=09$("#editioncloser").replace(data);
});
return false;
});
});
-->

</script>

<!-- HTML code for the input element that I will be replacing -->
<input type=3D"submit" value=3D" Lukk utgave " id=3D"editioncloser">


That's simple AJAX.

If you want to include JSON data and do DOM manipulation directly, you
can do JSON calls like this:

$.getJSON("/autodb/ajaxapi.wa2",{_cmd: cmd, xBoatType: xBoatType,
xBrand: xBrand, xModel: xModel}, function(j) {
var elm =3D document.forms['search'].elements[id];
RemoveChildren(elm);
for (var i=3D0; i<j.length; i++) {
AddOption(j[i].optValue, j[i].optDisplay, j[i].optSelected, elm=
);
}
})

Here, you need to have your callback method output "JSON", JavaScript
structures outputted over net. You can find examples of it on the
net; for a simple example, here's something that the above script
("ajaxapi.wa2") outputs for one of our structures:
[{optSelected: 0, optValue: 0, optDisplay: 'Alle (80)'},{optSelected:
0, optValue: 8001005, optDisplay: 'Fiskeb=E5t/Sjark (2)'},{optSelected:
0, optValue: 8001008, optDisplay: 'Gummib=E5t (0)'},{optSelected: 0,
optValue: 8001006, optDisplay: 'Jolle/=C5pen b=E5t (4)'},{optSelected: 0,
optValue: 8001010, optDisplay: 'Kano/Kajakk (0)'},{optSelected: 0,
optValue: 8001001, optDisplay: 'Motorb=E5t (64)'},{optSelected: 0,
optValue: 8001003, optDisplay: 'Motorseiler (0)'},{optSelected: 0,
optValue: 8001009, optDisplay: 'RIB (0)'},{optSelected: 0, optValue:
8001012, optDisplay: 'Seilbrett, (0)'},{optSelected: 0, optValue:
8001002, optDisplay: 'Seilb=E5t (8)'},{optSelected: 0, optValue:
8001007, optDisplay: 'Skj=E6rg=E5rdsjeep (0)'},{optSelected: 0, optValue:
8001004, optDisplay: 'Snekke (2)'},{optSelected: 0, optValue: 8001011,
optDisplay: 'Vannscooter (0)'}]

Notice how close it is to Ruby array/hash structure? The only thing
is that hash keys must be followed by : instead of =3D>. Remember to
escape your single-quotes; they almost certainly WILL show up even if
you're sure they won't. (Or at least they did for us...)

Hope that helped a bit.

Eivind.

Nicolas Antoniades

11/22/2007 2:32:00 PM

0

Hall=E5 Eivind.
E du svensk m=E5nne?
Har sv=E5rt o f=E5 tag p=E5 n=E5gon som faktskt kan f=F6rklara saker o ting=
...
/Nico

Giles Bowkett

11/22/2007 6:00:00 PM

0

The Ajax support in Rails is definitely more fully-developed than in
any other Ruby framework, but any Ruby framework can be used to
develop Ajax, and Rails' Ajax support is something of a mixed
blessing. Although it's in some respects very powerful, I've often had
to resort to feeding it BS commands just so it would generate its
code, which I would then copy, paste, and edit. It enables a lot of
stuff that seemed really cool in 2006 automatically, but any time you
need to do something even slightly different from what comes in the
box, you have to go to JavaScript to work with it manually. So Rails'
Ajax support is always *useful*, but it's really only *powerful* if
you understand how it works and have the ability to actually write
JavaScript when you need to.

I don't know how the Ajax support in other Ruby frameworks stacks up,
but I do know you have equivalent shortcuts in Seaside, and I did
attempt unsuccessfully to use Rails' Ajax shortcuts outside of Rails
the other day. In theory it should be really simple, but apparently
the theory must have been wrong, because in practice it was involved.

The Ajax support is mainly a set of JavaScript helper methods which
live in a library called ActionView, but I had to require its
companion library ActionController as well, and first - it has to come
first - in order for ActionView to properly load, or initialize, or
something. (Since both libraries live in a gem called actionpack, I
thought I could just require actionpack, but that doesn't work.) Once
you have both libraries required, and in the proper order, you can now
get to the JavaScript helper methods, but you still can't actually use
them. They implode due to the lack of a content_tag method. There's a
content_tag method within ActionView, so you can get to it, but I
didn't bother - I think probably you have to go through some more
steps to mimic Rails' loading process, and it seemed like an awful lot
of work.

Most of Rails' JavaScript helpers don't actually have any deep ties to
Rails, and would be useful for other frameworks as well, so it's a
pity this isn't easier to do. I do know where to look, probably - the
jRails plugin allows you to swap out Prototype and Scriptaculous with
jQuery instead, so the code for that is probably a good place to
start.

--
Giles Bowkett

Podcast: http://hollywoodgrit.bl...
Blog: http://gilesbowkett.bl...
Portfolio: http://www.gilesg...
Tumblelog: http://giles....

Miki Vz

11/26/2007 7:08:00 PM

0

I ended up using Camping and calling the Ajax by hand. I din't know how
good the Ajax libraries where, prototype, etc. It's easy enogh actually.
I still have trouble doing some things, but I hope to figure them out as
soon as I have a little time.

Cheers

-Miki

--
Posted via http://www.ruby-....