[
http://issues.apache.org/jira/browse/TAPESTRY-742?page=comments#action_12357106
]
Norbert Sándor commented on TAPESTRY-742:
-----------------------------------------
It would be very good, I've the same problem with LinkSubmit!
BR,
Norbi
/*
Please allow a little bit nostalgia :)
Once I've created a similar extension to Tapestry. However the implementation
was very QnD, so I used it only for researching reasons but not "in action" :)
There were several "open questions" in it :)
It was created long ago, so nowadays dojo/etc mechanisms would probably
deprecate it.
The main features were:
- a javascript library with basic functionality (inheritance, collections, etc.)
- *.jsobject.xml file for defining javascript classes with two parts
- pure javascript class definition part
- object creation part: this part created a new javascript representation of
the serverside component by passing parameters to the constructor of its class
This part allowed the following elements:
- ${...} is the same as in *.script
- $[...] converted the value to a javascript type, with converters for
primitive types, strings, arrays, collections
- $() inserted a reference to a component. This was a little bit tricky
because of foreach-like renderings in Tapestry.
So $(next:component) referenced the next (possibly) rendered instance of
the component, while $(last:component) referenced the last one.
These $() parts were translated to a valid clientside reference to the
javascript representation of the given component.
- the client and server side communicated using a datasqueezer-like construct
(but the clientside was able to squeeze a subset of the possible types, too,
eg. primitives, collections)
It wasn't easy to implement but finally ended up in trash :)
*/
> LinkSubmit renders overly verbose JavaScript
> --------------------------------------------
>
> Key: TAPESTRY-742
> URL: http://issues.apache.org/jira/browse/TAPESTRY-742
> Project: Tapestry
> Type: Improvement
> Components: Framework
> Versions: 4.0
> Reporter: Chris Conrad
>
> The LinkSubmit component currently renders a JavaScript function for every
> LinkSubmit on the page. This is problematic for me because I have a page
> which could have over 100 LinkSubmits on it (3 LinkSubmits per item with up
> to 50 items per page). The current JavaScript function which is rendered
> looks like:
> function onclick_LinkSubmit_0()
> {
> var form = Tapestry.find('Form');
>
> if (form.events.onsubmit_handler())
> {
> Tapestry.find('LinkSubmit_0').value = "T";
> form.onsubmit = null;
> form.submit();
> }
> }
> The LinkSubmit component could, however, add a static JavaScript file which
> contains a single function which looks like:
> function onclick_LinkSubmit(form, link)
> {
> var form = Tapestry.find(form);
>
> if (form.events.onsubmit_handler())
> {
> Tapestry.find(link).value = "T";
> form.onsubmit = null;
> form.submit();
> }
> }
> The values of 'form' and 'link' can be determined at script processing time
> and the function can be executed by creating a URL which look like:
> <a href="javascript:onclick_LinkSubmit('Form', 'LinkSubmit_0');">Do
> Something</a>
> This will substantially reduce the amount of JavaScript sent to the browser
> on a page which includes many LinkSubmits.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://issues.apache.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]