- Vic Gold
Thursday, July 31, 2008
Quote
- Vic Gold
Thursday, July 17, 2008
Ajax -loading javascript via AJAX
The facility comes with a cost:
The main issue with ajax is: say you have one.html with one.js and two.html with two.js files. Say, two.html when opened in IE displays a calendar (using client side js). Now when the two.html is loaded in one.html by ajax the calendar will not be rendered!!! Mozilla gets the two.js but not loads them... IE does'nt even do this. The general way of handling such issues is by including the two.js in one.html along with one.js.
Yeak!!!! what a dirty solution! The Yeak... 'cos why should the parent one.html know the existince of two.js at all?? Moreover... say the two.js is not always required/ say we have multiple js files three.js and four.js (each of them very big) and the user either uses three.js or four.js but not both... then by the above apporach we would include all the js-s in one.html forcing the browser to load all of them before hand.... so the page not only loads un-necessary js files but also takes a lot of time to load/ render... this has severe issues w.r.t performace and user experiance. Now imagine a case where we display 10 ajax pages each with its own sets of javascript!!! Here we developed a similar application and the initial page loads 19 (5+5+4+5) javascript files which made the page response time: 10.25 seconds on an avg. There should be a better soln.
A Refined solution:
Let the initial page load only one.js and by on-demand loading (or lazy-loading) lets load the required js files. This we can do by DOM-modifications or loading js files by eval function. I found a useful link On-Demand Javascript.
Dom Modifications:
Here the HTML DOM is modified and a script tag is written to its bottom as:
by using
once the writing to dom is done it will get the required js file and load it. The point is that the user should keep in mind to delete such codes when no longer being used. Good one.
XMLHttpRequest-Based On-Demand Javascript
In this case the js file is called and the text part of it is eval()-ed. I understood it only to this extent. eval(): is a function in java script which can be used to create dynamic javascript behavior.
eg:
var alrt = 'alert("hi")';
eval(alrt);
in this case the string alrt is taken evaluated and loaded resulting into an alert of hi. This is the same as writing alert('hi');
Example:
I used YUI -loader to do all this donkey work for me. FInally the code became so simple and clean after using this... I am amazed !!!! Its as follows.
testLoad.html
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<link rel="stylesheet" type="text/css"
      href="/yui/yui/assets/dpSyntaxHighlighter.css">
<script type="text/javascript" src="/yui/yui/build/yahoo/yahoo-debug.js">script>
<script type="text/javascript" src="/yui/yui/build/event/event-debug.js">script>
<script type="text/javascript" src="/yui/yui/build/dom/dom-debug.js">script>
<script type="text/javascript"
      src="/yui/yui/build/yuiloader/yuiloader-beta-debug.js">script>
head>
<body id="yahoo-com" class=" yui-skin-sam">
<div id="custom-doc" class="yui-t2">
<div id="bd">
<div id="ajaxContainer">div>
div>
div>
body>
<script type="text/javascript" src="basic.js" >script>
html>
Load = function(pageToLoad, whereToLoad) {
      var childContainerCount = 0;
      var scriptArr = new Array();
      var isRemoteJsFile = false;
      var loader = new YAHOO.util.YUILoader( {
            require : [ 'connection' ],
            base : [ '/yui/yui/build/' ],
            onFailure : function(o) {
                  alert("error: " + YAHOO.lang.dump(o));
            },
            onSuccess :fire
      });
      loader.insert();
      function lookupScript(text, index) {
            scriptArr = text.toLowerCase().split(');
            var js = scriptArr[index];
            var jsEnd;
            var jsStart;
            jsStart = js.indexOf('src');
            if (jsStart != -1) {
                  jsEnd = js.indexOf('.js');
                  // loading the js file
                  js = js.substring(jsStart + 3, jsEnd + 3);
                  js = js.replace('=', '');
                  js = js.replace('"', '');
                  //js = js.replace(/^\s\s*/, '').replace(/\s\s*$/, '');// trim
                  loadJs('yahooLang', '/yui/yui/build/yahoo/yahoo-min.js');
                  js = YAHOO.lang.trim(js);
            } else {
                  // loading script body
                  jsStart = js.indexOf('>');
                  jsEnd = js.indexOf(');
                  js = js.substring(jsStart + 1, jsEnd);
            }
            return js;
      }
      var loadJs = function(name, jsPath, initFunc) {
            loader = new YAHOO.util.YUILoader();
            loader.addModule( {
                  name :name,
                  type :"js",
                  fullpath :jsPath,
                  varName :initFunc
            });
            loader.filter = {
                  'searchExp' :"-min\\.js",
                  'replaceStr' :"-debug.js"
            };
            loader.require(name);
            loader.insert( {
                  onSuccess : function() {
                        if(initFunc != null && initFunc != undefined){
                              eval(initFunc + "()");
                        }
                  }
            });
      };
      function fire() {
            var parentDiv = document.getElementById(whereToLoad);
            var childDiv = document.createElement('div');
            childDiv.setAttribute('id', 'childContainer' + childContainerCount++);
            if (!whereToLoad && whereToLoad != undefined)
                  parentDiv.appendChild(childDiv);
            var handleSuccess = function(o) {
                  if (o.responseText !== undefined) {
                        scriptArr = o.responseText.toLowerCase().split(');
                        childDiv.innerHTML = o.responseText;
                        // loading each of the scripts of ajax file
                        for ( var i = 1; i <>
                              var js = lookupScript(o.responseText, i);
                              if (js.indexOf('.js') == -1) {
                                    eval(js);
                              } else {
                                    loadJs('ajaxJs' + i, js, 'initJs');
                              }
                        }
                  }
            }
            var handleFailure = function(o) {
                  if (o.responseText != undefined) {
                        alert('error');
                  }
            };
            var callback = {
                  success :handleSuccess,
                  failure :handleFailure,
                  argument : {
                        foo :"foo",
                        bar :"bar"
                  }
            };
            function makeRequest() {
                  var request = YAHOO.util.Connect.asyncRequest('POST', pageToLoad,
                              callback);
            }
            makeRequest();
      }
};
Load('/yui/yui/examples/yuiloader/one.html', 'ajaxContainer');
This will load a html page which has an inline content and an included external js file. Our aim is to be able to load them.
one.html
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document TITLE>
<script src="/yui/yui/examples/yuiloader/one.js" >
script>
<script>
      alert('hi hi hi hi 4');
script>
HEAD>
<BODY>
<font color="#FF0000"  > 22222222222222 font>
BODY>
HTML>
function initJs(){
      alert ('inside 2'); 
}
Solving Memory problems
CPU takes 100% usage and eclipse hangs.
Cause:
By default, Eclipse will allocate up to 256 megabytes of Java heap memory.
This should be ample for all typical development tasks. However, depending on
the JRE that you are running, the number of additional plug-ins you are using,
and the number of files you will be working with, you could conceivably have to
increase this amount. Eclipse allows you to pass arguments directly to the Java
VM using the
-vmargs command line argument, which must follow all other Eclipse specific arguments. Thus, to increase the available heap memory,
you would typically use:
Fix:
eclipse -vmargs -Xmx<memory size>
- Make a shortcut to the eclipse on desktop
- under target give: C:\pathToEclipse\eclipse\eclipse.exe -vmargs -Xmx768M
- For me even 512 was giving issues. Dont forget the M to the end else it would take it as Bytes!
Monday, July 14, 2008
Eclipse Ganymede
Java script support is more refined than the other tools that i had seen (aptana, jseclipse). you can check the available methods, scope of variables .. syntax errors etc... navigating to the source (f3) etc. But theres a big pain in the neck!!!! The tool is hanging whenever i open a javascript file. THis is happening only recently.... till then all happies... then i tried updating the new patches from the eclipse and now the cpu is 100% used.. all the system hangs.. huh!!!
now i retook the eclipse from the site.. and again configured ... now i see that cpu is only 50% consumed but eclipse is still hanging when ever i open a js file. not sure why this is happeing. i have configured abt 4 huge projects in eclipse 3 of them are pure java the last one all jsps and js-s (abt 100 jsps and 50 js) i am not sure if this is the issue... what ever ..... when ever i open a js file the eclipse hangs... hanging me.. i wait .. wait.. wait.. indefinitely and finally end task... huh!!! today i did it atleast 4 times...
---------
hey got a soln.. though dirty one: i had included YUI in the build path of javascript now i removed it and all is working fine... (yeak!!!! so i cant have YUI in build path??? terrible isnt it??)
Friday, July 4, 2008
Team outing to cruise (Tankbund lake + double decker boat)
The party was rocking... in fact i learnt that i don't know how to dance... in reality i was thinking that i dance well... not orsom though... but some spy(Arudra) had taken the video of my dance on the party and shown it to me... now i change my idea...: i am an upcoming dancer... :)
Eclipse Ganymede
Java script support is more refined than the other tools that i had seen (aptana, jseclipse). you can check the available methods, scope of variables .. syntax errors etc... navigating to the source (f3) etc. But theres a big pain in the neck!!!! The tool is hanging whenever i open a javascript file. THis is happening only recently.... till then all happies... then i tried updating the new patches from the eclipse and now the cpu is 100% used.. all the system hangs.. huh!!!
now i retook the eclipse from the site.. and again configured ... now i see that cpu is only 50% consumed but eclipse is still hanging when ever i open a js file. not sure why this is happeing. i have configured abt 4 huge projects in eclipse 3 of them are pure java the last one all jsps and js-s (abt 100 jsps and 50 js) i am not sure if this is the issue... what ever ..... when ever i open a js file the eclipse hangs... hanging me.. i wait .. wait.. wait.. indefinitely and finally end task... huh!!! today i did it atleast 4 times...
---------
hey got a soln.. though dirty one: i had included YUI in the build path of javascript now i removed it and all is working fine... (yeak!!!! so i cant have YUI in build path??? terrible isnt it?? )
 
